Стефан Дэвис - С++ для чайников .

Здесь есть возможность читать онлайн «Стефан Дэвис - С++ для чайников .» весь текст электронной книги совершенно бесплатно (целиком полную версию без сокращений). В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Город: Москва, Год выпуска: 2007, ISBN: 2007, Издательство: Издательский дом Вильямс. Компьютерное издательство Диалектика, Жанр: Технические науки, Программирование, Программы, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

С++ для чайников .: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «С++ для чайников .»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

empty-line
1
empty-line
4

С++ для чайников . — читать онлайн бесплатно полную книгу (весь текст) целиком

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «С++ для чайников .», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯

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 Использование потоков вводавывода - фото 301

279 стр Глава 24 Использование потоков вводавывода - фото 302

_________________

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. Полезные особенности

Все попытки обратиться к объекту классаofstream который содержит ошибку не - фото 303

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «С++ для чайников .»

Представляем Вашему вниманию похожие книги на «С++ для чайников .» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «С++ для чайников .»

Обсуждение, отзывы о книге «С++ для чайников .» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.

x