Студопедия
Случайная страница | ТОМ-1 | ТОМ-2 | ТОМ-3
АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатика
ИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханика
ОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторика
СоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансы
ХимияЧерчениеЭкологияЭкономикаЭлектроника

Лабораторная работа №8

Читайте также:
  1. A) дохода лица, работающего по найму и b) дохода самозанятого лица.
  2. III. Работа над темой
  3. Quot;Бедные и средний класс работают ради денег". "Богатые заставляют деньги работать на себя".
  4. Quot;РАБОТА" ЛЮБВИ
  5. V. Самостоятельная работа студентов.
  6. V.Игра «Мы работаем на фабрике».
  7. VIII. Самостоятельная работа студентов

Тема: «Управление вводом/выводом и файловые системы»

(2 часа)

Информация во внешней памяти (на диске) хранится в виде файлов – именованных объектов, доступ к которым обеспечивает операционная система. Поддержка ОС состоит в том, что в ней имеются средства:

· Создания файлов;

· Уничтожения файлов;

· Поиска файлов на внешнем носителе информации;

· Чтения и записи данных из файлов и в файлы;

· Открытия файлов;

· Закрытия файлов;

· Позиционирования файлов.

Рассматривая взаимосвязь файлов с потоками ввода/вывода, следует отметить существование следующих процедур:

· Создание файла;

· Создание потока;

· Открытие файла;

· «присоединение» файла к потоку;

· обмены с файлом с помощью потока;

· «отсоединение» файла от потока;

· закрытие файла;

· уничтожение файла.

Все перечисленные действия могут быть выполнены с помощью средств библиотеки классов ввода/вывода языка С++.

Потоки для работы с файлами создаются как объекты следующих классов:

· ofstream – для вывода (записи) данных в файл;

· ifstrem – для ввода (чтения) данных из файла;

· fstream – для чтения и для записи данных (двунаправленный обмен).

Пример:

#include<fstream.h>

ofstream outFile; /*определяет выходной файловый поток*/

ifstream inFile; //определяет входной файловый поток

fstream ioFile; /*определяет файловый поток для ввода и вывода*/

Создание файлового потока связывает имя потока с выделяемым для него буфером и инициализирует переменные состояния потока.

Открытие файла в самом общем смысле означает процедуру, информирующую систему о тex действиях, которые предполагается выполнять с файлом.

Создав файловый поток, можно "присоединить" его к конкретному файлу с помощью компонентной функции open(). С ее помощью можно не только открыть файл, но и связать его с уже определенным потоком. Формат функции:

void open (const char *fileName,

int mode=умалчиваемое_значение,

int protection=умалчиваемое_значение);

Первый параметр – fileName – имя уже существующего или создаваемого заново файла. Это строка, определяющая полное или сокращенное имя файла в формате, регламентированном операционной системой. Второй параметр - mode (режим) – дизъюнкция флагов, определяющих режим работы с открываемым файлом(например, только запись или только чтение). Флаги определены следующим образом:

enum ios::open_mode {

in = 0x01, // Открыть только для чтения

out = 0x02, // Открыть только для записи

ate = 0x04,//При открытии искать конец файла

app =0x08,//Дописывать данные вконец файла

trunk =0x10,// Вместо существующего создать новый файл,

nocreate=0x20,//Не открывать новый файл (Для несуществующего файла функция open выдаст ошибку)

noreplace=0x40,// Не открывать существующий файл (Для существующего выходного файла, не имеющего режимов ate или арр, выдать ошибку)

binary=0x80,//Открыть для двоичного (не текстового) обмена.

}

Умалчиваемое значение параметра mode зависит от типа потока, для которого вызывается функция open ().

Третий параметр - protection (защита) - определяет защиту и достаточно редко используется. Точнее, он устанавливается по умолчанию, и умалчиваемое значение обычно устраивает программиста.

Открытие и присоединение файла к конкретному файловому потоку обеспечивается таким вызовом функции open():

имя_потока.open (имя_файла, режим, защита);

Здесь имя_потока - имя одного из объектов, принадлежащих классам ofstream, ifatream, fstream. Примеры вызовов для определенных выше потоков:

outFile.open(“C:\\X\\RESULT.DAT");

inFile.open("DATA.TXT");

ioFile.open("CHAHGE.DAT", ios:: out);

При открытии файлов с потоками класса ofstream второй параметр по умолчанию устанавливается равным ios::out, т.е. файл открывается только для вывода. Таким образом, файл C:\X\RESULT.DAT после удачного выполнения функции open() будет при необходимости (если он не существовал ранее) создан, а затем открыт для вывода (записи) данных в текстовом режиме обмена и присоединен к потоку outFile. Теперь к потоку outFile может применяться, например, операция включения «, как к стандартным выходным потокам cout, cerr.

Поток inFile класса ifstream в нашем примере присоединяется функцией open() к файлу с именем DATA.TXT. Этот файл открывается для чтения из него данных в текстовом режиме. Если файла с именем DATA.TXT не существует, то попытка вызвать функцию inFile.open() приведет к ошибке.

Для проверки удачности завершения функции ореn() используется следующая конструкция:

if(!inFile)

{ cerr << "Ошибка при открытии файла!\n"; exit(l); }

Для потоков класса fstream второй аргумент функции ореn() должен быть задан явно, так как по умолчанию неясно, в каком направлении предполагается выполнять обмен с потоком.

В классе fstreambase, который служит основой для файловых классов, имеются и другие средства для открытия уже существующих файлов.

Если файл явно создан с помощью библиотечной функции "нижнего уровня" create(), то для него определен дескриптор файла. Этот дескриптор можно использовать в качестве фактического параметра функции fstreambase::attach(). При вызове этой функции используется уточненное имя, содержащее название того потока, который предполагается присоединить к уже созданному файлу с известным дескриптором:

В классах ifstream, ofstream, fstream определены конструкторы, позволяющие по-иному выполнять создание и открытие файлов.

Работая со средствами библиотечных классов ввода-вывода, чаще всего употребляют конструктор без параметров и конструктор, в котором явно задано имя файла. Примеры обращений к конструкторам без параметров:

ifstream fi; // Создает входной файловый поток fi

ostream fo; // Создает выходной файловый поток fo

fstream ff; //Создает файловый поток ввода-вывода ff

После выполнения каждого из этих конструкторов файловый поток можно присоединить к конкретному файлу, используя уже упомянутую компонентную функцию open ():

fi.open("Filel.txt",ioe::in); // Поток fi соединен с файлом Filel.txt

fi.close(); // Разорвана связь потока fi с файлом Filel.txt

fi.open(“File2.txt”); // Поток fi присоединен к файлу File2.txt

fo.open("NewFile"); // Поток fо присоединяется к файлу NewFile; если такой файл отсутствует - он будет создан

При обращении к конструктору с явным указанием в параметре имени файла остальные параметры можно не указывать, они выбираются по умолчанию.

Примеры:

ifstream flowl("File.l");

создает входной файловый поток с именем flow1 для чтения данных. Разыскивается файл с названием File.1. Если такой файл не существует, то конструктор завершает работу аварийно. Проверка: if (!flowl) cerr << "Не открыт файл File.l!";

ofstream flow2(“File.2”);

создается выходной файловый поток с именем flow2 для записи информации. Если файл с названием File.2 не существует, он будет создан, открыт и соединен с потоком flow2. Если файл уже существует, то предыдущий вариант будет удален и пустой файл создается заново.

fstream flow3("File.3");

создается файловый поток flow3, открывается файл File.3 и присоединяется к потоку flow3.

Функцию close(), позволяющую очистить буфер потока, отсоединить поток от файла и закрыть файл необходимо явно вызывать при изменении режимов работы с файловым потоком. Автоматически эта функция вызывается только при завершении программы.


Дата добавления: 2015-07-11; просмотров: 87 | Нарушение авторских прав


Читайте в этой же книге: Лабораторная работа №1 | Лабораторная работа №2 | Лабораторная работа №3 | Лабораторная работа №6 | Лабораторная работа №7 |
<== предыдущая страница | следующая страница ==>
Задание на выполнение| Лабораторная работа №9

mybiblioteka.su - 2015-2025 год. (0.011 сек.)