Подпрограммы в авс pascal

Содержание

Слайд 2

Подпрограмма - это часть программы, описывающая некоторый алгоритм, который можно многократно

Подпрограмма - это часть программы, описывающая некоторый алгоритм, который можно многократно

использовать, обращаясь к нему из различных точек программы.
Применение подпрограмм дает возможность уменьшать число повторений одной и той же последовательности операторов.
Это позволяет получить более логичный процесс программирования.
Слайд 3

Выполнение программы, имеющую подпрограмму, начинается с выполнения основной программы. Как только

Выполнение программы, имеющую подпрограмму, начинается с выполнения основной программы. Как только

в программе идет обращение к подпрограмме, данные из основной программы (входные данные) передаются в подпрограмму, которая начинает выполняться.
Затем результаты подпрограммы (выходные данные) передаются в основную программу в то место, откуда был сделан вызов подпрограммы, и продолжает выполняться основная программа.
Слайд 4

Подпрограмма оформляется подобно основной программе, т.е. состоит из заголовка, раздела описаний,

Подпрограмма оформляется подобно основной программе, т.е. состоит из заголовка, раздела описаний,

раздела операторов.
Операторы подпрограммы, окаймленные операторными скобками begin..end, называются телом этой подпрограммы.
Слайд 5

Все имена, представленные в разделе описаний основной программы, называются глобальными. Они

Все имена, представленные в разделе описаний основной программы, называются глобальными. Они

действуют как в разделе операторов основной программы, так и в любой подпрограмме.
Имена, представленные в разделе описаний подпрограммы, называют локальными. Они действуют только в рамках подпрограммы и недоступны операторам основной программы.
Слайд 6

В языке Паскаль имеется два вида подпрограмм: процедура (PROCEDURE), функция (FUNCTION)

В языке Паскаль имеется два вида подпрограмм:
процедура (PROCEDURE),
функция (FUNCTION)

Слайд 7

Функции являются частным случаем процедур и принципиально отличаются от них следующим:

Функции являются частным случаем процедур и принципиально отличаются от них следующим:
1.

результат выполнения функции - одно значение, а процедуры - одно или несколько;
2. результат выполнения функции передается в основную программу как значение имени этой функции, а результаты выполнения процедуры - как значения ее параметров.
Слайд 8

Описание процедуры имеет вид: procedure имя(список формальных параметров); раздел описаний begin операторы end; Процедуры

Описание процедуры имеет вид:
procedure имя(список формальных параметров);
раздел описаний
begin
операторы
end;

Процедуры

Слайд 9

Список формальных параметров состоит из одной или нескольких секций, разделенных символом

Список формальных параметров состоит из одной или нескольких секций, разделенных символом

";". Каждая секция состоит из списка переменных, перечисляемых через запятую, после которого следуют двоеточие и тип.
Каждая секция может предваряться служебным словом var, что указывает на то, что параметры передаются по ссылке.
Список формальных параметров вместе с окружающими скобками может отсутствовать.
Слайд 10

Раздел описаний процедуры или функции устроен так же, как и раздел

Раздел описаний процедуры или функции устроен так же, как и раздел

описаний основной программы.
Здесь описываются так называемые локальные переменные и константы, типы а также вложенные процедуры и функции. Все такие локальные объекты доступны лишь внутри данной подпрограммы и не видны извне.
Слайд 11

Пример . Процедура меняет местами первый и последний, второй и предпоследний

Пример . Процедура меняет местами первый и последний, второй и предпоследний

и т.д. элементы массива.
procedure Reverse(var a: array [1..100] of integer; n: integer); var i,v: integer; begin for i:=1 to n div 2 do begin v:=a[i]; a[i]:=a[n-i+1]; a[n-i+1]:=v; end; end;
Слайд 12

Описание функции имеет вид: function имя(список формальных параметров): тип возвращаемого значения;

Описание функции имеет вид:
function имя(список формальных параметров): тип возвращаемого значения;
раздел описаний


begin
операторы
end;

Функции

Слайд 13

Внутри тела функции имя этой функции можно использовать как специальную переменную,

Внутри тела функции имя этой функции можно использовать как специальную переменную,

которой необходимо присвоить возвращаемое значение. Например:
function Add(a,b: real): real;
begin Add:=a+b; end;
Имя функции может быть использовано с целью возврата значения только в левой части оператора присваивания.
Если имя функции встречается в выражении, то это трактуется как рекурсивный вызов этой функции.
Слайд 14

Вместо имени функции, внутри тела функции можно использовать другую специальную переменную

Вместо имени функции, внутри тела функции можно использовать другую специальную переменную

с именем Result. В отличие от имени функции, переменную Result можно использовать и в выражениях:
function Min(var a: array [1..100] of real; n: integer): real; var i: integer; begin Result:=a[1]; for i:=1 to n do if a[i]
Слайд 15

Если внутри функции не присвоить имени функции или переменной Result некоторое

Если внутри функции не присвоить имени функции или переменной Result некоторое

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

Параметры, указываемые при описании подпрограммы, называются формальными. Параметры, указываемые при вызове

Параметры, указываемые при описании подпрограммы, называются формальными. Параметры, указываемые при вызове

подпрограммы, называются фактическими.
Если формальный параметр описан со служебным словом var, то его называют параметром-переменной и говорят, что он передается по ссылке.
Если же параметр описан без слова var, то его называют параметром-значением и говорят, что он передается по значению.

Параметры процедур и функций

Слайд 17

Если параметр передается по значению, то при вызове подпрограммы значения фактических

Если параметр передается по значению, то при вызове подпрограммы значения фактических

параметров присваиваются соответствующим формальным параметрам. При этом изменение формального параметра не приводит к изменению фактического.
Слайд 18

Если параметр передается по ссылке, то при вызове подпрограммы фактический параметр

Если параметр передается по ссылке, то при вызове подпрограммы фактический параметр

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

При передаче параметра по ссылке в подпрограмму передается адрес фактического параметра.

При передаче параметра по ссылке в подпрограмму передается адрес фактического параметра.


Поэтому если параметр занимает много памяти (массив, запись), то обычно он также передается по ссылке.
В результате в процедуру передается не сам параметр, а его адрес, что экономит память и время работы.
Слайд 20

В качестве фактического параметра-значения можно указывать любое выражение, тип которого совпадает

В качестве фактического параметра-значения можно указывать любое выражение, тип которого совпадает

с типом формального параметра или неявно к нему приводится.
В качестве фактического параметра-переменной можно указывать только переменную, тип которой в точности совпадает с типом формального параметра.
 Параметр может быть также описан со служебным словом const (вместо var). Это означает, что менять его в подпрограмме запрещено.
Слайд 21

Локальные и глобальные переменные Переменные, описанные в разделе описаний подпрограммы, называются

Локальные и глобальные переменные

Переменные, описанные в разделе описаний подпрограммы, называются ее

локальными переменными. Переменные же, описанные вне подпрограммы, называются глобальными по отношению к ней.
Параметры подпрограммы считаются ее локальными переменными.
Если имя локальной переменной совпадает с именем глобальной переменной, то локальная переменная скрывает глобальную, так что к глобальной переменной нельзя обратиться внутри подпрограммы.
Слайд 22

Пример 1. Вычислить число сочетаний Для вычисления факториала использовать функцию.

Пример 1. Вычислить число сочетаний

Для вычисления факториала использовать функцию.

Слайд 23

Слайд 24

Пример 2. Даны три массива. Вычислить сумму элементов каждого из них.

Пример 2. Даны три массива. Вычислить сумму элементов каждого из них.

Для

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

Слайд 26

Слайд 27

Пример 3. Из диапазона целых чисел от n до m выписать простые числа.

Пример 3. Из диапазона целых чисел от n до m выписать

простые числа.