¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯
ios::app— Дописывать в конец файла. Вернуть ошибку, если файл не существует
ios::ate— Дописывать в конец файла, если он существует
ios::in— Открыть файл для ввода ( подразумевается для istream )
ios::out— Открыть файл для вывода ( подразумевается для ostream )
ios::trunc— Обрезать файл до нулевой длины, если он существует ( используется по умолчанию )
ios::nocreate— Если файла не существует, вернуть сообщение об ошибке
ios::noreplace— Если файл существует, вернуть сообщение об ошибке
ios::binary— Открыть файл в бинарном режиме ( альтернатива текстовому режиму )
¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯
Таблица 24.3. Значения аргумента prot в конструкторе класса ofstream
_________________
Флаг — Назначение
¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯
filebuf::openprot— Режим совместного чтения и записи
filebuf::sh_none— Исключительный режим без совместного доступа
filebuf::sh_read— Режим совместного чтения
filebuf::sh_write— Режим совместной записи
¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯
Приведённая ниже программа открывает файл MyName.txt , а затем записывает в него некоторую важную информацию.
/* StreamOutput — простой вывод в файл */
#include
using namespace std ;
int main( int nNumberofArgs , char* pszArgs[ ] )
{
setlocale ( LC_ALL , ".1251" ) ; /* печать русских текстов */
ofstream my( "MyName.txt" ) ;
my << "С++ для чайников — очень хорошая книга"
<< endl ;
system( "PAUSE" ) ; return 0 ;
}


_________________
279 стр. Глава 24. Использование потоков ввода-вывода
Конструктор ofstream::ofstream( char* ) получает только имя, а потому использует для режима открытия файла значения по умолчанию. Если файл MyName.txt уже существует, он урезается; в противном случае создаётся новый файл MyName.txt . Кроме того, файл открывается в режиме совместного чтения и записи.
Второй конструктор, ofstream::ofstream( char* , int ) , позволяет программисту указывать другие режимы ввода-вывода. Например, если бы я захотел открыть файл в бинарном режиме и произвести запись в конец этого файла ( если он уже существует ), я мог бы создать объект класса ofstream так, как это показано ниже ( напомню, что в бинарном режиме при выводе не выполняется преобразование символа новой строки \n в пару символов перевода каретки и новой строки \r\n , так же как при вводе не происходит обратного преобразования ).
void fn( )
{
/* Откроем бинарный файл BINFILE для записи; если он существует, дописываем информацию в конец файла */
ofstream bfile( "BINFILE", ios::binary | ios::ate ) ;
/* ...продолжение программы... */
}
Потоковые объекты хранят информацию о состоянии процесса ввода-вывода. Функция-член bad( ) возвращает TRUE , если при работе с файловым объектом произошло что-то "плохое". Сюда входят такие неприятности, как невозможность открыть файл, нарушение внутренней структуры и т.п. Функция fail( ) указывает, что либо произошла ошибка, либо последнее чтение было неудачным. Функция good( ) возвращает TRUE, если и bad( ) , и fail( ) возвращают FALSE . Функция clear( ) используется для сброса флага ошибки. Вот как выглядит добавление простейшей обработки ошибок к рассмотренной нами программе.
/* StreamOutputWithErrorChecking — простой вывод в файл */
#include
#include
using namespace std ;
int main( int nNumberofArgs , char* pszArgs[ ] )
{
setlocale ( LC_ALL , ".1251" ) ; /* печать русских текстов */
const static char fileName[ ] = "MyName.txt" ;
ofstream my( fileName ) ;
if ( my.bad( ) ) /* Открыть не удалось... */
{
cerr << "Ошибка открытия файла "
<< fileName
<< endl ;
return 0 ; /* ...вывод сообщения и завершение работы */
}
my << "С++ для чайников — очень хорошая книга"
<< endl ;
if ( my.bad( ) )
{
cerr << "Ошибка записи в файл "
<< fileName
<< endl ;
}
system( "PAUSE" ) ; return 0 ;
}
_________________
280 стр. Часть 5. Полезные особенности

Читать дальше