
- •Введение
- •Часть 1. Основные сведения о языке Free Pascal
- •Глава 1. Хранение данных
- •Глава 2. Основные операторы
- •Глава 3. Условные операторы
- •Глава 4. Циклы
- •Глава 5. Подпрограммы
- •Глава 6. Стандартные математические подпрограммы
- •Глава 7. Модификаторы подпрограмм
- •Глава 8. Инкремент и декремент
- •Глава 9. Работа с консолью
- •Глава 10. Массивы
- •Глава 11. Указатели
- •Глава 12. Динамическое распределение памяти
- •Глава 13. Процедурный тип
- •Глава 14. Множества
- •Глава 15. Обработка строк
- •Глава 16. Записи
- •Глава 17. Упакованные сущности
- •Глава 18. Перезагрузка операторов
- •Глава 19. Определение типа во время выполнения программы
- •Глава 20. Работа с файлами
- •Глава 21. Структура программы
- •Глава 22. Области видимости данных
- •Часть 2. Сопровождение и повышение надежности программ
- •Глава 1. Комментарии
- •Глава 2. Завершение программы
- •Глава 3. Параметры командной строки
- •Глава 4. Обработка ошибок
- •Глава 5. Модули
- •Часть 3. Объектно-ориентированное программирование
- •Глава 1. Принципы объектно-ориентированного программирования
- •Глава 2. Классы
- •Глава 3. Наследование
- •Глава 4. Вспомогательные классы
- •Глава 5. Ссылки на классы
- •Глава 6. Интерфейсы
- •Часть 4. Концепция объектов вне классов
- •Глава 1. Объекты без классов
- •Глава 2. Динамические объекты
- •Глава 3. Расширенные записи
- •Часть 5. Создание программ с графическим интерфейсом
- •Глава 1. Средства быстрой разработки
- •Глава 2. Описание элементов графического интерфейса
- •Глава 3. Проектирование в Lazarus
- •Глава 4. Основные элементы интерфейса
- •Глава 5. Диалоги
- •Глава 6. Таймер
- •Глава 7. Запуск программ
- •Заключение
- •Список литературы

Определение процедуры:
procedure имя процедуры(параметр1;...параметрN); alias псевдоним; Объявления переменных и констант
begin
тело процедуры end;
Определение функции:
function имя функции(параметр1;...параметрN):тип; alias псевдоним; Объявления переменных и констант
begin
тело функции end;
Предварительные объявления
Предварительные объявления используются для описания подпрограмм, чье определение будет дано позже. Само определение подпрограммы делается обычным образом.
Формат предварительного объявления для процедуры: procedure имя процедуры(параметр1;...параметрN); forward;
Формат предварительного объявления для процедуры: function имя функции(параметр1;...параметрN):тип; forward;
Глава 6. Стандартные математические подпрограммы
Подпрограмма |
Описание |
Abs(число); |
Модуль числа |
Arctan(число); |
Арктангенс |
Cos(число); |
Косинус |
Sin(число); |
Синус |
Sqr(число); |
Квадрат числа |
Sqrt(число); |
Квадратный корень числа |
Round(число); |
Округление числа с плавающей точкой до ближайшего целого |
Randomize; |
Инициализация генератора случайных чисел |
Random(число); |
Возвращает случайное значение в диапазоне от 0 до число-1 |
14
Глава 7. Модификаторы подпрограмм
Общие сведения
Модификаторы могут быть использованы в определениях подпрограмм. Модификатор указывается сразу после имени подпрограммы после точки с запятой. В конце модификатора так же ставиться точка с запятой. Использование модификаторов не является обязательным.
Обработчики файлов
Модификатор iocheck указывает на то, что функция является обработчиком файловых операций и может возвращать код ошибки. Обычно модификатор iocheck встречается в модулях, которые идут вместе с компилятором Free Pascal.
Встраиваемые подпрограммы
Для встраиваемых подпрограмм используется модификатор inline. Для таких подпрограмм вызов заменяется вставкой кода из тела подпрограммы. Читатель знакомый с языком Си, заметит, что концепция встраиваемых подпрограмм в рассматриваемом здесь диалекте паскаля совпадает с концепцией языка Си.
Ограничения встраиваемых подпрограмм:
1.Недопустима рекурсия и вызов других подпрограмм
2.В версиях Free Pascal ниже 2.0.2 встраиваемая подпрограмма не может экспортироваться из модуля
3.Директива inline носит рекомендательный характер и при отсутствии возможности использования встраиваемых подпрограмм, компилятор генерирует обычные подпрограммы
Программная эмуляция математического сопроцессора на процессорах ARM
Используйте модификатор softfloat чтобы задействовать программную эмуляцию математического сопроцессора на процессорах ARM. Математический сопроцессор применяется для обработки чисел с плавающей точкой.
Внешние подпрограммы
Модификатор external указывает на то, что подпрограмма будет находиться во внешнем объектном файле. Модификатор export указывает на то, что подпрограмма может быть импортирована из подключаемой библиотеки.
15

Модификаторы, определяющие область видимости
Модификатор |
Описание |
local |
Локальные подпрограммы не могут быть экспортированы из |
|
библиотек, но позволяют обойтись без прототипов, если |
|
подпрограмма расположена в модуле. |
public |
Публичные подпрограммы недоступны в модуле, но могут |
|
вызываться из объектных файлов. |
Модификаторы, которые влияют на передачу аргументов в подпрограмму
Существует ряд модификаторов, влияющих на внутренний механизм передачи аргументов в подпрограммы.
Модификатор |
Описание |
cdecl |
Стиль вызова Си. Аргументы помещаются в стек справа налево. |
|
Очистку стека выполняет вызывающая подпрограмма. |
pascal |
Стиль вызова Паскаль. Аргументы помещаются в стек слева |
|
направо. Очистку стека выполняет вызванная подпрограмма. |
stdcall |
Аргументы помещаются в стек справа налево. Очистку стека |
|
выполняет вызванная подпрограмма. |
safecall |
Аргументы помещаются в стек справа налево. Очистку стека |
|
выполняет вызванная подпрограмма. Состояние регистров |
|
сохраняется перед вызовом и восстанавливается после выхода |
|
из подпрограммы. |
register |
Аргументы передаются через регистры процессора. |
saveregisters |
Аргументы передаются через регистры процессора. Состояние |
|
регистров сохраняется перед вызовом подпрограммы. |
interrupt |
Аргументы передаются через регистры процессора. Состояние |
|
регистров восстанавливается после выхода из подпрограммы. |
nostackframe |
Запрещает использовать стек для функции. |
vargs |
Используется для подпрограмм с переменным числом |
|
аргументов. |
Глава 8. Инкремент и декремент
Инкрементом называется увеличение значения на единицу. Декремент выполняет обратное действие. Для этих операций предусмотрены две подпрограммы. Подпрограмма Inc выполняет инкремент. Подпрограмма Dec выполняет декремент. Они берут имя переменной как аргумент.
16
Глава 9. Работа с консолью
Что такое консоль?
Программы без графического интерфейса работают с консолью. Этим термином называют клавиатуру при выполнении операций ввода данных. Консолью называют дисплей при выполнении операций вывода данных.
Ввод данных с консоли
Чтобы ввести данные с клавиатуры используйте процедуру read или readln. При вызове этих процедур выполнение программы приостанавливается до тех пор, пока пользователь не введет нужные данные.
Ввод заканчивается нажатием клавиши Enter. Переменным присваиваются введенные значения.
Процедура readln переводит курсор на новую строку после окончания ввода.
Обе процедуры берут имя переменной в качестве аргумента. Оно заменяется списком имен, если необходимо ввести несколько значений. Имена в списке отделяются запятой.
При вводе нескольких значений они разделяются пробелом.
Вывод данных на консоль
Для вывода данных на экран используйте процедуру write или writeln. Процедура writeln переводит курсор на новую строку после окончания вывода. Формат передачи аргументов этим процедурам совпадает с форматом процедуры read.
Глава 10. Массивы
Зачем нам массивы?
Массивом называют последовательность однотипных данных. К отдельному элементу массива обращаются по его номеру. Размерностью называют количество элементов массива.
Многомерным называют массив, состоящий из других массивов. Часто используют двумерные массивы. Они представляют собой матрицы. С матрицами вы можете быть знакомы из курса математики. Математики называют таблицу чисел матрицей.
17
Объявление массива
Синтаксис объявления массива: var имя: array[размерность] of тип;
Размерность указывает количество элементов в массиве.
Формат задания размерности: номер первого..номер последнего элемента В многомерном массиве следующая размерность указывается после запятой.
Доступ к отдельному элементу массива
К отдельному элементу массива можно обращаться как к переменной, поместив номер элемента в квадратных скобках после имени массива. Для многомерных массивов нужно указывать и следующую размерность.
Предположим, что у нас имеется двухмерный массив с именем matrix. Тогда доступ к элементу первой строки первого столбца осуществляется через конструкцию matrix[1][1].
Открытые массивы
Для использования массивов произвольной длинны в качестве аргументов подпрограмм применяются специальные параметры, называемые открытыми массивами.
Формат объявления параметра: имя: array of тип
Динамические массивы
Динамическим называют массив, память под который выделяется во время работы программы.
Синтаксис объявления динамического массива: var имя: array of тип;
Память под массив выделяется при помощи подпрограммы SetLength.
Формат вызова подпрограммы SetLength: SetLength(имя,размерность).
Размерность задается, как число определяющее количество элементов. В многомерном массиве следующая размерность указывается после запятой.
Память автоматически освобождается, как только динамический массив перестает использоваться. Используйте следующую конструкцию, чтобы освободить память вручную: имя массива:=nil;
Нумерация в динамических массивах
В динамических массивах нумерация подчиняется жестким правилам.
Первый элемент имеет номер 0. Номер последнего элемента на единицу меньше размерности массива. Выход за границы массива может повредить данные.
18