Объектный подход к файлам

Базовый объект TStream (поток) позволяет абстрагироваться от поня­тия «файл» и его носителя. Файл представляет собой непрерывный поток символов без всякой заранее определенной структуры. Рассмотрим работу объекта TFileStream одного из потомков объекта TStream, предназна­чен­ного для работы с файлами на жестком диске.

Для работы с этим объектом используются следующие методы.

Create(S;M:Word) ‑ создание файла под именем S в режиме M: fmCreate (создание нового файла), fmOpenRead (для чтения), fmOpenWrite (для записи), fmOpenReadWrite (для чтения и записи).

Free ‑ закрытие файла.

Read(Var B;N:LongInt):LongInt‑ чтение в переменную B очередных N бай­­тов, начиная с текущей позиции. Возвращается число прочитанных байтов.

Write(B;N:LongInt):LongInt ‑ запись из переменной B в файл N байтов, на­чи­ная с текущей позиции. Возвращается число выведенных байтов.

Seek(N:LongInt;O:Word):LongInt ‑ установка текущей позиции в файле пу­тем смещения на N байтов (отсчет с нуля) относительно O: soFrom­Be­gin­ning (от начала файла), soFromCurrent (от текущей позиции файла), soFromEnd (от конца файла и N<=0).

SetSize(N:LongInt) ‑ установка нового размера файла, равного N байтам.

CopyFrom(S:TStream;N:LongInt):LongInt ‑ копирование первых N байтов файла ‑ объекта S в текущий файл ‑ объект. Возвращается число фактичес­ки скопированных байтов.

В распоряжении имеются два свойства объекта: Size(размер файла), Position(текущая позиция файла от его начала).

Пример формирования и чтения файла «d:\prim.dat»:

Procedure TForm1.Button1Click(Sender: TObject); //обработка кнопки

Var S:TFileStream; B:Array [1..3] Of Char; //переменные

Begin Try S:=TFileStream.Create('d:\prim.dat',fmCreate); //открытие файла

S.Write('0123456789',10); //вывод в файл текста «0123456789»

S.Free; {закрытие файла} S:=TFileStream.Create('d:\prim.dat',fmOpenRead);

S.Seek(5,soFromBeginning); //установка текущей позиции на пятый байт

S.Read(B,3); Label1.Caption:= Copy(Z,1,3); //вывод из файла цифр 5,6,7

Finally S.Free; {закрытие файла в любом случае} End; End;

Файлы Windows

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

Атрибуты файлов задаются именованными константами: faRead­On­ly (только чтение), faHidden (скрытый), faSysFile (системный), faVolum­ID (имя диска), faDirectory (каталог), faArchive (архив), faAnyFile (любой).

Режимы доступа при открытии файла задаются константами:

fmOpenRead (только чтение), fmOpenWrite (запись), fmOpenReadWrite (чте­ние и запись), fmShareCompat (совместимый с FCB), fmShareExclusive (мо­но­поль­ное использование), fmShareDenyWrite (запрет записи для дру­гих приложений), fmShareDenyRead (запрет чтения для других при­ло­жений), fmShareDenyNone (многопользовательский разделяемый режим).

В системе Windows каждый файл вместо файловой переменной имеет уникальный цифровой дескриптор, называемый обычно Hanle (он обозначен в описаниях процедур и функций буквой H), значение которого формируется функциями открытия файла FileCreate или FileOpen:

FileCreate(S)‑ создание файла под именем S, возвращение его дескриптора.

FileOpen(S;M:Integer) ‑ открытие уже существующего файла S в режиме M (комбинация fmXXXX и fmShareXXXX, соединенных операциями Or), и возвращение его дескриптора.

Запрещается одновременное использование для одного файла функции и процедур файлов Паскаля и Windows.

Приведем список других основных процедур и функций.

FileClose(H) ‑ закрытие файла с дескриптором H (см. FileCreat, FileOpen).

FileGetDate(H):Integer ‑ возвращает в формате DOS дату и время создания открытого файла с дескриптором H.

FileRead(H;Var B;N:Integer):Integer ‑ читает N байтов из открытого файла c дескриптором H в переменную B и возвращает число cчитанных байтов.

Обычно переменной B является одномерный массив элементов типа Сhar.

FileSeek(H,N,O:Integer):Integer ‑ устанавливает в открытом файле c дес­крип­тором H позицию со смещением N от начала (O=0) текущего положе­ния (O=1) или от конца (O=2) файла соответственно. Возвращает новую по­зицию или -1 в случае ошибки.

FileSetDate(H,A:Integer):Integer ‑ устанавливает в формате DOS дату и время создания (A) открытого файла с дескриптором H и возвращает 0 при успешном выполнении, иначе - код ошибки Windows. Дату можно получить из значения типа TDateTime функцией DateTimeToFileDate.

FileWrite(H;B;N:Integer):Integer ‑ записывает N байтов в открытый файл c дескриптором H из переменной B и возвращает число выведенных байтов.

Пример:

Procedure TForm1.Button1Click(Sender: TObject); //обработка кнопки

Var H:Integer; S,Z: Array [1..5] of Char; //объявление переменных

Begin Try H:=FileCreate('c:\prim.dat'); //открытие создаваемого файла

S:='12345';FileWrite(H,S,SizeOf(S));{вывод S}FileClose(H);//закрытие файла

H:=FileOpen('c:\prim.dat',fmOpenRead); //открытие файла для чтения

FileSeek(H,‑4,2);//пропуск назад от конца файла 4 байта, текущая позиция 2

FileRead(H,Z,3);//вывести из файла три байта, начиная с текущего второго

Label1.Caption:=Copy(Z,1,3); //вывод Z в метку (будет текст: 234)

Finally FileClose(H); {закрытие файла в любом случае} End; End;








Дата добавления: 2016-03-22; просмотров: 572;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.006 сек.