Процедура BlockRead

Считывает одну или большее количество записей из файла в переменную.

Объявление:

<p>Procedure BlockRead(Var F : File; Var Buf; Count :Word [; Var Result : Word]);  </p>                 
<p>Где:<br />
F - нетипизированная файловая переменная <br />
Buf - любая переменная  <br />
Count - выражение типа <br />
Word Result - переменная типа Word.</p>

Режим: 

Замечания:

Процедура BlockRead считывает Count или меньшее количество записей из файла F в блок памяти, начинающийся с первого байта, занятого переменной Buf. Реальное количество прочитанных записей (меньшее или равное Count) возвращается в необязательном параметре Result. Если параметр Result не определен, то в случае, когда количество прочитанных записей не равно параметру Count, происходит ошибка ввода/вывода.

Весь считанный блок занимает максимум Count * RecSize байт, где RecSize - размер записи, определяемый при открытии файла (или 128 байт, если размер записи не был определен). Если Count * RecSize больше, чем 64Кб, то происходит ошибка.

Параметр Result является необязательным. Если весь запрошенный блок был считан, то Result будет равно Count. Иначе, в случае, если Result меньше, чем Count, то конец файла был достигнут прежде, чем было завершено и параметр RecSize был больше 1, то Result вернет количество целиком считанных записей.

Указатель текущей позиции файла перемещается на количество записей, равное значению параметра Result.

В режиме {$I-} функция IOResult вернет нуль, если операция была успешной, иначе, она вернет отличный от нуля код ошибки.

Файл должен быть открыт.

Пример программы: blockrd.pas

См. также:  BlockWrite