Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 10
На сайте нет зарегистрированных пользователей

Пользователей: 13,368
новичок: Goosprin
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Моделирование процесса обеспечивающего надежность функционирования АСУ Т...
Лабораторная работа по динамическим спискам на Turbo Pascal (удаление ду...
Моделирование процесса поступления заявок в систему, состоящую из трёх Э...

Текстовые файлы
Для того чтобы открыть требуемый файл, нужно просто объявить объект соответствующего типа, указав параметры конструктора, который берет на себя всю работу. По умолчанию файл считается текстовым. Закрывать файл тоже не требуется, так как при уничтожении объекта всю работу выполнит деструктор. Напишем простой пример создания и чтения текстового файла oonumber.txt (листинг 14.2). Нам нужно предварительно создать на диске С папку TextFiles — все текстовые файлы будем записывать в нее.
Листинг 14.2. Создание текстового файла
#include <fstream>
#include <iostream> // требуется в Visual С++.NET 2003
#include <ctime> using namespace std; int main()
{ srand((unsigned)time(NULL)); // инициализация датчика случайных чисел /* открываем выходной текстовый файл для записи */ { ofstream strm("c:/textfiles/oonumber.txtM); for(int i = 0; i < 10; i++) // выводим 10 чисел strm << rand()%10 << '\n';
} // деструктор закроет файл
/* открываем тот же текстовый файл для чтения */
{ ifstream strm("c:/textfiles/oonumber.txt");
char ss[20] = {0};
while(true)
{ strm.getline(ss, 20); // читаем числа как строки
if (strm.eof()) break; // проверяем признак конца файла
cout << ss << '\n'; // выводим на экран
}
} // опять деструктор закрывает файл return EXIT_SUCCESS;
}



Обратите внимание на внутренние блоки в теле функции ma i п (). Внутри блоков объявлены объекты-потоки: в первом — выходной, во втором — входной. Больше ничего не требуется, так как объявление объекта одновременно и открывает файл, и связывает поток с файлом, а при выходе из блока деструктор закрывает файл и разрывает связь. Мы не только не задаем явных операций открытия и закрытия, но еще и не указываем режима открытия файла — все это реализовано в конструкторе соответствующего класса по умолчанию.
Напишем ту же программу в более традиционном виде — с открытием и закрытием, с проверкой ошибок открытия. Вместо простого вывода на экран содержимого файла просуммируем числа, записанные в файл (листинг 14.3).
Листинг 14.3. Создание файла и суммирование чисел
#include <fstream>
#include <iostream> // требуется в Visual C++.NET 2003
#include <ctime> using namespace std; int main()
{ srand((unsigned)time(NULL)); // датчик случайных чисел
ofstream strm; // выходной поток-объект
strm.open("c:/textfiles/oonumber.txt"); // открываем
if (strm.is_open()) // проверка открытия
{ for(int i = 0; i < 10; i++) // выводим 10 чисел
strm << rand()%10 << '\n';
strm.close(); // закрываем выходной поток-файл
// суммирование чисел, записанных в файле
// открываем тот же текстовый файл для чтения
ifstream strm("с:/textfiles/oonumber.txt");
if (strm) // проверка открытия
{ int number, summa = 0, count = 0;
while(strm ¦>> number) // ввод числа
{ ++count; // подсчет количества
summa+=number; // суммирование
}
cout << summa << "; " << count; // вывод результатов
strm.close(); // закрываем поток-файл
}
}
return EXIT SUCCESS;



Так же легко написать программу копирования файлов (листинг 14.4). Если не проверять ошибки, то программа получается очень простой!

Листинг 14.4. Копирование файлов
#include <fstream> #include <ctime> using namespace std;
// функция копирования потока in в поток out; потоки должны быть открыты void filecopy(ifstream &in, ofstream &out) { char ch;
while(in.get(ch)) // читать все символы, в том числе пробельные
out.put(ch);
}
int main()
{ ifstream instrm {"c:/textfiles/oonumber.txt"); ofstream outstrm("c:/textfiles/oonumber.new"); if (instrm) filecopy(instrm, outstrm); // копирование файлов return EXIT_SUCCESS;
}



Заглянув в каталог TextFiles, мы обнаружим там два файла: исходный oonumber.txt и новый oonurnber.new. Просмотрев оба файла в Блокноте (Notepad), можно убедиться в их идентичности.
Необходимо обратить внимание на функцию копирования: параметры должны передаваться по ссылке, так как в процессе операций чтения и записи состояние потоков изменяется. Никакой другой способ передачи параметров не работает.
Функция копирования может быть и такой:
void filecopy(ifstream &in, ofstream &out) { char ch;
while(in.read(&ch, 1)) // читать все символы, в том числе пробельные out.write(&ch,l);
}



И еще один вариант функции копирования:
void filecopy(ifstream &in, ofstream &out) { char ch = in.getO ;
while(!in.eof ())
{ out.put(ch);
ch = in.getO; // читать все символы, в том числе пробельные
}
}


Опубликовал Kest March 16 2014 22:32:32 · 0 Комментариев · 5995 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Дарахвелидзе П., ...
Калькулятор [Исхо...
Черный круг двига...
Counter [Исходник...
Разработка распре...
TrayComp
Самоучитель PHP 4
Введение в станда...
iChat v.7.0 Final...
Векторный редакто...
Delphi 6/7 базы д...
Графика в проекта...
CLR via C#
AVIwriter
DiskInfo
С# для профессион...
Панель Календарь
Handles
Распознавание иде...
Х. М. Дейтел, П. ...

Топ загрузок
Приложение Клие... 100774
Delphi 7 Enterp... 97833
Converter AMR<-... 20268
GPSS World Stud... 17014
Borland C++Buil... 14191
Borland Delphi ... 10291
Turbo Pascal fo... 7373
Калькулятор [Ис... 5984
Visual Studio 2... 5207
Microsoft SQL S... 3661
Случайные статьи
10 Заблуждений при...
Что означает равен...
О рекламе и о спаме
Видео формат
Стандартные компон...
Подари себе Интерн...
Программа выбирает...
НЕОДНОЗНАЧНЫЕ ГРУППЫ
Анализ скорости вы...
Эти точки должны б...
Вулкан - ваш стары...
Bases for Allsubmi...
Работа в режиме HT...
Резервное копирова...
Форматирование выв...
2. Безопасность DH...
Классы
Глава 3
Первый служит для ...
STORAGE (ПАМЯТЬ)
Уроки Python для н...
Использование Visu...
Too many open files
Файлы посещений: м...
Добавление в проек...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?