Главная страница Случайная страница Разделы сайта АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника |
💸 Как сделать бизнес проще, а карман толще?
Тот, кто работает в сфере услуг, знает — без ведения записи клиентов никуда. Мало того, что нужно видеть свое раписание, но и напоминать клиентам о визитах тоже.
Проблема в том, что средняя цена по рынку за такой сервис — 800 руб/мес или почти 15 000 руб за год. И это минимальный функционал.
Нашли самый бюджетный и оптимальный вариант: сервис VisitTime.⚡️ Для новых пользователей первый месяц бесплатно. А далее 290 руб/мес, это в 3 раза дешевле аналогов. За эту цену доступен весь функционал: напоминание о визитах, чаевые, предоплаты, общение с клиентами, переносы записей и так далее. ✅ Уйма гибких настроек, которые помогут вам зарабатывать больше и забыть про чувство «что-то мне нужно было сделать». Сомневаетесь? нажмите на текст, запустите чат-бота и убедитесь во всем сами! Листинг 16.17. Добавление данных в конец файла
1: #include < fstream.h> 2: int main() // возвращает 1 в случае ошибки 3: { 4: char fileName[80]; 5: char buffer[255]; 6: cout < < " Please re-enter the file name: "; 7: cin > > fileName; 8: 9: ifstream fin(fileName); 10: if (fin) // файл уже существует? 11: { 12: cout < < " Current file contents: \n"; 13: char ch; 14: while (fin.get(ch)) 15: cout < < ch; 16: cout < < " \n***End of file contents.***\n"; 17: } 18: fin.close(); 19: 20: cout < < " \nOpening " < < fileName < < " in append mode...\n"; 21: 22: ofstream fout(fileName, ios:: app); 23: if (! fout) 24: { 25: cout < < " Unable to open " < < fileName < < " for appending.\n"; 26: return(1); 27: } 28: 29: cout < < " \nEnter text for the file: "; 30: cin.ignore(1, '\n'); 31: cin.getline(buffer, 255); 32: fout < < buffer < < " \n"; 33: fout.close(); 34: 35: fin.open(fileName); // переопределение существующего объекта fin! 36: if (! fin) 37: { 38: cout < < " Unable to open " < < fileName < < " for reading.\n"; 39: return(1); 40: } 41: cout < < " \nHere's the contents of the file: \n"; 42: char ch; 43: while (fin.get(ch)) 44: cout < < ch; 45: cout < < " \n***End of file contents.***\n"; 46: fin.close(); 47: return 0; 48: }
Результат: Please re-enter the file name: test1 Current file contents: This line written directly to the file... This text is written to the file! ***End of file contents.*** Opening test1 in append mode... Enter text for the file: More text for the file! Here's the contents of the file: This line written directly to the file... This text is written to the file! More text for the file! ***End of file contents.***
Анализ: Пользователю вновь предлагается ввести имя файла, после чего в строке 9 создается объект файлового потока ввода. В строке 10 проверяется наличие на диске указанного файла и, если он уже существует, его содержимое выводится на экран строками 12—16. Обратите внимание на то, что выражение if(fin) аналогично if(fin. good()). Файл ввода закрывается и снова открывается, однако теперь в режиме добавления (строка 22). После этого открытия (как, впрочем, после каждого открытия) выполняется проверка правильности открытия файла. В этом случае условие if(! fout) подобно условию if (fout.fail()). Пользователю предлагается ввести текст, после чего в строке 33 файл закрывается. Наконец, как и в листинге 16.16, файл открывается в режиме чтения, но в этом случае не нужно повторно объявлять объект fin. Он просто связывается с тем же именем файла. После проверки правильности открытия файла в строке 36 содержимое файла выводится на экран и он окончательно закрывается.
Рекомендуется: Постоянно проверяйте правильность открытия файла. Повторно используйте уже существyющиe oбъeкты ifstream и ofstream. Закрывайте все объекты fstream по завершении работы с ними.
Не рекомендуется: Не пытайтесь закрыть или переопределить объекты cin и cout.
|