|
Программирование >> Операторы преобразования типа
Перенаправление вывода в файл strm.rdbuf (file.rdbufO); file one row for the file endl; strm one row for the stream endl; Восстановление старого выходного буфера strm.rdbuf (strm buffer); } Автоматическое закрытие файла И буфера Результат выполнения программы выглядит так: the first row the last row Содержимое файла redirect.txt: one row for the file one row for the stream Как видите, данные, записанные в поток данных cout внутри функции redirect(), были переданы в файл (по имени параметра strm), а даииые, записанные в main() после вьшолнения redirect(), попали в восстановленный выходной канал. Потоки чтения и записи в последнем примере связывания один поток данных используется как для чтения, так и для записи. Обычно файл открывается для чтения/записи при помощи класса fstream: std::fstream file ( example.txt . std::ios::1n std::1os::out): Также можно использовать два разных потоковых объекта, по одному для чтения и записи. Соответствующий фрагмент может выглядеть примерно так: std:iOfstream out ( example.txt . 1os::in ios::out): std::1stream in (out.rdbuf0): Объявление out открывает файл. Объявление in использует потоковый буфер out для чтения из него. Обратите внимание: поток данных out должен открываться для чтения и записи. Если открыть его только для записи, чтение из потока данных приведет к непредсказуемым последствиям. Также обратите внимание на то, что in определяется не с типом ifstream, а только с типом istream. Файл уже открыт, и у него имеется соответствующий потоковый буфер. Все, что требуется, - это второй потоковый объект. Как и в предыдущих примерах, файл закрывается при уничтожении объекта файлового потока данных. Также можно создать буфер файлового потока данных и назначить его обоим потоковым объектам. Решение выглядит так: std::filebuf buffer: std::ostream out(&buffer): std::istream 1n (&buffer): buffer.openCexample.txt , std:;1os::in std::ios::out): Объект filebuf является обычной специализацией класса basic filebuf< > для типа char. Класс определяет потоковый буфер, используемый файловыми потоками данных. В следующем примере с помощью цикла в файл выводится четыре строки. После каждой операции вывода все содержимое файла записывается в стандартный выходной поток данных: iol/rwl.cpp #include <iostream> finclude <fstrea[n> using namespace std: int mainO { Открытие файла example.dat для чтения и записи filebuf buffer; ostream output(Sbuffer): Istream inputC&buffer): buffer.open ( examp1e.dat . 1os::1n ios::out 1os::trunc); for Cint i=l: i<=4; i++) { Запись одной строки output 1 . line endl: Вывод всего содержимого файла input.seekg(O); Позиционирование в начало char С; while (Input.get(c)) { cout.put(c): cout endl; input.clearO; Сброс флагов eofbit и failbit Результат выполнения программы выглядит так: 1. line 1. line 2. line 1. line 2. line 3. line 1. line 2. line 3. line 4. line Хотя для чтения и записи используются два разных объекта потоков данных, позиции чтения и записи тесно связаны между собой. Функции seekgO и seekp() вызывают одну и ту же функцию потокового буфера . Следовательно, для того чтобы вывести все содержимое файла, необходимо всегда устанавливать позицию чтения в начало файла. После вывода всего содержимого файла позиция чтения/записи снова перемещается в конец файла для присоединения новых строк. Операции чтения и записи с одним файлом должны разделяться операцией позиционирования (кроме выхода за конец файла во время чтения). Пропуск операции позиционирования приведет к искажению содержимого файла или еще более фатальным ошибкам. Как упоминалось выше, вместо последовательной обработки символов все содержимое файла можно вывести одной командой, для чего оператору << передается указатель на потоковый буфер: std::cout input.rebufO; Потоковые классы для работы со строками Механизм потоковых классов также может использоваться для чтения или записи в строки. У строковых потоков данных имеется буфер, но нет канала ввода-вывода. Для работы с буфером/строкой используются специальные функции. Основная область применения строковых потоков данных - обработка вводимых/выводимых данных независимо от фактического механизма ввода-вывода. Например, выводимый текст можно отформатировать в строке и передать в выходной канал позднее. Другой вариант - ввод данных по строкам и обработка строк с использованием строковых потоков данных. Исходные потоковые классы для строк в стандартной библиотеке С++ были заменены набором новых классов. Раньше в классах строковых потоков данных для представления строк использовался тип char*. Теперь для этой цели используется тип string (или в общем случае - basic strjng<>). Прежние классы стрюко-вых потоков данных также являлись частью стандартной библиотеки С++, но сейчас они считаются устаревшими. Они продолжают поддерживаться для обеспечения обратной совместимости, но могут быть исключены из будущих версий стандарта. Прежние классы в новые программы включаться не будут, а в унаследованном коде произойдет их постепенная замена. Тем не менее на с. 623 приводятся краткие описания таких классов. Классы строковых потоков данных Для строк определены следующие потоковые классы, которые являются аналогами соответствующих классов файловых потоков данных: О шаблон basicjstringstream со специализациями istringstream и wistringstream для чтения из строк ( строковый входной поток данных -); В общем случае эта функция различает изменяемую позицию (чтение, запись, обе позиции). Только буферы стандартных потоков данных поддерживают одау позицию и для чтения, и для записи.
|
© 2006 - 2025 pmbk.ru. Генерация страницы: 0.001
При копировании материалов приветствуются ссылки. |