Смекни!
smekni.com

Процедури та функції в Turbo Pascal (стр. 1 из 2)

Житомирський військовий інститут національного авіаційного університету

Реферат

на тему:

Процедури та функції в TurboPascal

Житомир 2010

1. Загальні відомості про процедури та функції

Автономна частка програми (яка реалізує визначений алгоритм і припускає звертання до неї із різних часток загальної програми) називається підпрограмою.

Розміщення підпрограм у програмі схоже з ієрархічним принципом побудови файлової системи (рис.1).

Рис. 1.

Позитивні сторони використання підпрограм:

1) реалізується метод структурного програмування (блочна, модульна побудова);

2) економія пам’яті (яка виділяється для зберігання змінних підпрограми тільки під час роботи підпрограми);

3) імена змінних в основній програмі і підпрограмах незалежні (потр. змінна А програми і підпрограми можуть мати різні фізичні значення);

4) самостійний характер підпрограм дозволяє їх створення різними користувачами, що прискорює процес програмування.

В мові Паскаль виділяють два види підпрограм:

- процедура (PROCEDURE);

- функція (FUNCTION).

Принципи побудови Паскаль-програми, процедури і функції ідентичні і відрізняються тільки заголовками.

Форма заголовків:

Program <ім’я> (список параметрів)

Procedure <ім’я> (список параметрів)

Function <ім’я> (список параметрів)

Блоки можуть бути незалежними або вкладеними один в одного. Відповідно вони носять назву зовнішнього або внутрішнього (рис.1).

Рис. 2. Принцип блочної побудови програми

Змінні і константи можна описувати у зовнішніх або внутрішніх блоках. Тому виникає два поняття змінних і констант: локальні і глобальні.

Локальні – існують у рамках того блока, де вони описані. Тобто за межами даного блока їх використовувати не можливо.

Глобальні – описані у зовнішньому блоці але використовують у внутрішньому блоці.

Правила локалізації змінних:

1) змінна (константа) існує в рамках того блока де вона описана;

2) кожна змінна в межах блока повинна бути описана тільки один раз;

3) якщо у внутрішньому блоці використовується змінна, яка описана у зовнішніх блоках, то діє тільки опис самого внутрішнього блоку (найближчого);

4) якщо змінна описана як у внутрішньому так і у зовнішньому блоках, то при переході до внутрішнього блока опис зовнішнього блока не використовується, тобто діє опис внутрішнього блоку. При переході до зовнішнього блока знову починається дія опису зовнішнього блока.

2. Процедури з параметрами та без параметрів

Процедури з параметрами (методика розробки)

· процедура складається із заголовка і блока. Блок будується стандартно і не відрізняється від блока програми за винятком того, що наприкінці процедури ставиться крапка з комою.

· Ім’я вибирають довільно. Параметри, які містяться у списку параметрів, носять назву формальних – тобто вони не приймають ніяких значень, а тільки позначають місця, на які далі будуть поставлені так звані фактичні параметри. Параметри позначають початкові дані (аргументи) і результати виконання процедури.

· Список параметрів складається із окремих секцій, які відокремлюють крапкою з комою ( ; ). В секції вказується перелік (список) параметрів і через двокрапку їх тип.

Наприклад:

Procedure R( x, y : real; k : integer; var s : real);

Тут параметри x і y вказують першу секцію, k – другу, s – третю. В даному прикладі x, y, k – параметри-значення; s – оператор-змінна, перед яким повинно стояти службове слово var. Параметри-значення – аргументи функції, а параметри-змінні – результати виконання процедури.

Приклад 2.1.1 розробки процедури:

Procedure Sum (a, b : real; var y, z : real);

const n=10;

var i : integer;

begin

for i := 1 to n do

begin

y := a + b * i;

z := 4 * y – i;

end;

end

Тут a і b – вхідні параметри, їх значення передаються із основної програми в цю процедуру. Результати процедури (вихідні параметри)є обчислені значення y і z, які передаються із процедури в основну програму і там можуть бути використані.

Методика використання процедури у зовнішньому блоці

Для використання процедур існує так званий оператор процедури:

<ім’я процедури> (список фактичних параметрів)

Ім’я повинноспівпадати з іменем записаної процедури. Параметри у дужках носять назву фактичних. Вони відповідають реальним змінним, над якими виконують операції. Фактичні і формальні параметри повинні відповідати одне одному за містом їх розміщення і типом. Список фактичних параметрів не містить типів даних, бо вони вже вказані у списку формальних параметрів.

Program PR;

procedure P(x, y : real; var z : real );

end;

begin

P(a, b, c);{виклик процедури}

end

Приклад 2.2.1

в програмі визначити довжину кола C і площі круга S, обмеженого цим колом; відстань L центра кола від початку координат О. Координати центра кола – x, y, радіус кола – R.

Program KOLO (input, output);

var R: real; {радіус}

x, y: real;{координати центра}

C: real;{довжина кола}

S: real;{площа круга}

L: real;{відстань від центру}

Procedure KRUG (R, x, y : real; var C, S, L : real);

const pi = 3.14;

begin

C:= 2 * pi * R;

S:= pi* sqr ( R );

L:= sqrt ( sqr(x) + sqr(y));

end;

begin

writeln (‘ ввести R, x , y :‘);

read (x, y , R);

KRUG (R, x ,y, C, S, L);

writeln (‘довжина кола = ’, C : 6 : 2);

writeln (‘площа кола = ’, S : 6 : 2);

writeln (‘відстань = ’, L : 6 : 2);

end.

Суть (трактовка) параметрів-значень і параметрів змінних

Розглянемо особливості передачі параметрів із зовнішнього блоку до внутрішнього.

1-й спосіб – підстановка на місце формальних параметрів обчислених значень фактичних параметрів. Наприклад (див. приклад 2.1.1):

Sum (3.5, 7.6, y, z);

2-й спосіб – підстановка замість формальних параметрів імен фактичних параметрів:

Sum (x1, x2, y, z);

При цьому результати процедури завжди отримують імена (і не обов’язково співпадають з іменами формальних параметрів). Наприклад:

Sum (x1, x2, С, D);

Розглянемо можливі варіанти опису фактичних параметрів у зовнішньому блоці і відповідне звертання до процедури.

Таблиця 2.1

І. Procedure P(x : тип; y : тип; var z : тип);
1

A – const; B - const;

C – var

P (A, B, C)
2

A – var; B – var;

C – var

A := F1; B := F2;

P (A, B, C);

або read (A, B);

P (A, B, C);

3 C – var; P (3, 4 ,C);
ІІ. Procedure P1(var x : тип; var y : тип; var z : тип);
4

A – var;

B – var;

C – var;

A := F1; B :=F2;

aбо

read (A, B);

P1 (A, B, C);

Коментарій табл.2.1:

1) фактичні параметри A і B у зовнішньому блоці описані як const і замінюють формальні параметри – значення x, y процедури Р;

2) фактичні параметри А і В обчислюються або вводяться у зовнішньому блоці перед вставленням їх у процедуру;

3) фактичні параметри А і В не об’явлені. Тому замість їх імен вставленні конкретні значення 3 і 4;

4) всі параметри задані як змінні, тому при формуванні модифікованого тіла процедури на місце формальних параметрів підставлені імена фактичних параметрів.

Процедури без параметрів

В таких процедурах замість формальних параметрів використовують глобальні змінні. Використання процедур без параметрів потребує уваги і коректності при складанні програм, точного дотримання правил локалізації змінних.

Приклад 2.2.1а:

Program KOLO1 ( input, output );

var R, x, y, С, S, L : real;

procedure KRUG;

const pi = 3.14;

begin

C := 2 * pi * R;

S := pi* sqr ( R );

L := sqrt ( sqr(x) + sqr(y));

end;

begin

writeln ( ‘ ввести R, x , y :‘);

read ( x, y , R);

KRUG ;

writeln (‘довжина кола = ’, C : 6 : 2);

writeln (‘площа кола = ’, S : 6 : 2);

writeln (‘відстань від центра = ’, L : 6 : 2);

end.


Змінні, яки використані у процедурі описані як глобальні (R, x, y, C, S, L).

3. Особливості використання функцій

Особливості функцій:

1) має тільки один результат виконання (процедури дозволяють отримати ряд результатів для різних параметрів);

2) результат позначається іменем функції і передається в основну програму, тому імені функції присвоюють необхідний тип даних;

3) форма побудови функції відрізняється від процедури тільки заголовком;

4) можна викликати в середині виразу:

F := FAСT (M) – FAСT (K);

Приклади заголовків функції:

1) FUNCTION f (a, b :real) : real;

a і b – дійсні параметри значення; f – ім’я функції, яка отримає результат виконання функції типу real.

2) FUNCTION f1 (x : real; var y, z : integer) : real;

x - дійсний параметр-значення;

y, z – цілі параметри-змінні;

Суть параметрів-значень і параметрів-змінних аналогічна процедурам

3) FUNCTION f2 : real;

без параметрів.

Приклад 3.1: знайти різницю факторіалів F = m! – k!, де m! = 1*2*3*...*m; k! = 1*2*3*...* k.

FUNCTION FACT ( n: integer) : real;

var i : integer;

p : real;

begin

p :=1;

for i := 1 to n do

p := p * i;

FACT := p;

end;

Викликається функція як і процедура з використанням фактичних параметрів (наприклад, m i k):

F := FAСT (M) – FAСT (K);

Таким чином, якщо процедури і функції розробляються для багаторазового використання, краще їх виконувати з використанням параметрів, щоб досягнути максимальної незалежності від тієї програми, де вона використовується.

4. Методи звертань до процедур і функцій

Існує 3 варіанта звертання до процедур і функцій:

1) із зовнішнього блоку (цей спосіб розглянули у попередніх питаннях лекції);

2) із сусідньої функції;

3) із самої функції – рекурсія.