Применение рекурсии в алгоритмах с возвратом. Файловый тип. Ввод/вывод
| Категория реферата: Рефераты по математике
| Теги реферата: банк рефератов 5 баллов, вопросы и ответы
| Добавил(а) на сайт: Эльмпт.
Предыдущая страница реферата | 1 2 3 4 | Следующая страница реферата
false: WriteLn ('Нет путей :-(');
end;
end;
End.
Файловый тип. Ввод/вывод.
Все рассмотренные ранее типы данных обладали одним общим свойством - число их компонентов конечно и заранее фиксировано. Однако, существует достаточно широкий класс задач, когда количество компонент данных заранее не известно. Пример - задача кодирования текста поступающего на вход в реальном времени, ввод текста, длина которого заранее не известна и т.п.
В Pascal существует тип данных, множество элементов которого есть последовательности однотипных элементов, длина этих последовательностей не фиксируется заранее. Важной характеристикой этого типа, называемого файловым, является то, что доступ к его компонентам строго последовательный. Это означает, чтобы получить доступ к i-му компоненту, необходимо пройти i-1-ый.
Файловый тип - это единственный тип, обладающий тем свойством, что данные этого типа могут иметь время жизни более времени выполнения программы ! Поэтому этот тип часто используют, чтобы сохранить результаты работы программы для последующей обработки; либо ввести данные извне. Примеры файлового типа, с которыми мы уже много раз встречались много раз - input и output.
Файлы и работа с ними.
<описание файлового типа>::= file of <тип компонент>
Тип компонент - любой, не содержащий файлового. Файлы бывают внутренние и внешние. Внутренние файлы имеют время жизни не больше, чем время выполнения программы. Внешние файлы описываются в заголовке программы, в скобках, после имени программы:
program <имя программы>(<список внешних файлов>);
В списке внешних файлов указываются те файлы, чье время жизни больше времени выполнения программы. Если файл не указан в этом списке - он внутренний, т.е. время его жизни равно времени выполнения программы. Внутренние и внешние файлы следует описать как файловые переменные в разделе описания переменных программы:
<имя файла> :<файловый тип>
Над файлами не определено никаких операций, для них не определен даже оператор присваивания.
Для доступа к компонентам файла в Pascal предопределены специальные процедуры : rewrite(f); reset(f); read(f, x);write(f, x); get(f); put(f); и специальная переменная, так называемая буферная переменная f^. На примерах излагаются правила работы и использования перечисленных выше средств работы с файлами. Также рассматривается текстовый файл.
Действия над файлами делятся на 2 группы:
Установка режима работы с файлом
Доступ к компонентам
К первой группе относятся 2 процедуры
rewrite(f) - открывает файл для записи и устанавливает окно на начало
reset(f) - открывает файл для чтения и устанавливает окно на начало
В каждый момент времени имеется доступ только к одной компоненте файла - окно файла или буферная переменная (обозначаемая символом f^, где f - имя файла). Эта переменная имеет тип компоненты файла.
Для последовательного доступа к компонентам файла в Pascal определены 2 процедуры:
read (f:file of <тип>, var x:<тип>) - читает компоненту из файла f, открытого для чтения, записывает эту компоненту в переменную x и передвигает окно файла на 1 компоненту.
write (f:file of <тип>, x:<тип>) - записывает компоненту x в файл f, открытый для записи и передвигает окно файла на 1 компоненту.
В качестве параметров для этих процедур можно вместо x:<тип> передавать список переменных этого типа. В этом случае несколько компонент файла будут прочитаны или записаны и окно файла сдвинется на соответствующее количество компонент.
Рекомендуем скачать другие рефераты по теме: исторические рефераты, куплю диплом.
Категории:
Предыдущая страница реферата | 1 2 3 4 | Следующая страница реферата