Показаны различия между двумя версиями страницы.
Предыдущая версия справа и слева Предыдущая версия Следующая версия | Предыдущая версия | ||
cp:obx-proc-type [2017/12/27 08:20] иван_денисов |
cp:obx-proc-type [2024/08/28 10:41] (текущий) theathlete [Пример] |
||
---|---|---|---|
Строка 1: | Строка 1: | ||
- | ===== Использование процедурных типов ===== | + | ====== Использование процедурных типов |
Суть этой возможности в **Компонентном Паскале** состоит в том, что можно создать // | Суть этой возможности в **Компонентном Паскале** состоит в том, что можно создать // | ||
Строка 7: | Строка 7: | ||
==== Пример ==== | ==== Пример ==== | ||
- | < | + | < |
- | MODULE | + | MODULE |
- | IMPORT sl := StdLog; | + | |
- | TYPE | + | |
- | tP = PROCEDURE (IN str: ARRAY OF CHAR); | + | |
- | PROCEDURE Test1 (IN str: ARRAY OF CHAR); | + | IMPORT Out := StdLog; |
- | BEGIN | + | |
- | sl.String(' | + | |
- | END Test1; | + | |
- | | + | TYPE |
- | | + | CalculatorLong = PROCEDURE (VAR acc: LONGINT; cur: INTEGER); |
- | sl.String('Test2:=' + str); sl.Ln | + | |
- | END Test2; | + | |
- | | + | PROCEDURE |
- | VAR | + | BEGIN acc := acc + cur END Add; |
- | pp: tP; | + | |
- | str: ARRAY 40 OF CHAR; | + | PROCEDURE Sub(VAR acc: LONGINT; cur: INTEGER); |
- | BEGIN | + | BEGIN acc := acc - cur END Sub; |
- | | + | |
- | | + | PROCEDURE Mul(VAR acc: LONGINT; cur: INTEGER); |
- | pp(str); | + | BEGIN acc := acc * cur END Mul; |
- | | + | |
- | | + | PROCEDURE Div(VAR acc: LONGINT; cur: INTEGER); |
- | pp(str) | + | BEGIN acc := acc DIV cur END Div; |
- | END Start; | + | |
- | END TestProcedure. | + | PROCEDURE Greater(VAR acc: BOOLEAN; a, b: INTEGER); |
- | TestProcedure.Start | + | BEGIN acc := acc & (a > b) END Greater; |
+ | |||
+ | PROCEDURE Less(VAR acc: BOOLEAN; a, b: INTEGER); | ||
+ | BEGIN acc := acc & (a < b) END Less; | ||
+ | |||
+ | PROCEDURE ReduceLong(IN nums: ARRAY OF INTEGER; c: CalculatorLong): | ||
+ | VAR | ||
+ | i: INTEGER; | ||
+ | acc: LONGINT; | ||
+ | BEGIN | ||
+ | acc := nums[0]; | ||
+ | FOR i := 1 TO LEN(nums) - 1 DO c(acc, nums[i]) END; | ||
+ | RETURN acc; | ||
+ | END ReduceLong; | ||
+ | |||
+ | PROCEDURE ReduceBool(IN nums: ARRAY OF INTEGER; c: CalculatorBool): | ||
+ | VAR | ||
+ | i: INTEGER; | ||
+ | acc: BOOLEAN; | ||
+ | BEGIN | ||
+ | acc := TRUE; i := 1; | ||
+ | REPEAT | ||
+ | | ||
+ | INC(i); | ||
+ | UNTIL (i = LEN(nums)) OR ~acc; | ||
+ | RETURN acc; | ||
+ | END ReduceBool; | ||
+ | |||
+ | PROCEDURE Start*; | ||
+ | VAR | ||
+ | sn: ARRAY 5 OF INTEGER; (* sn - some nums *) | ||
+ | orderedNums: | ||
+ | sum, mul: LONGINT; | ||
+ | greater, less: BOOLEAN; | ||
+ | BEGIN | ||
+ | sn[0] := 1; sn[1] := 3; sn[2] := 5; sn[3] := 7; sn[4] := 9; | ||
+ | |||
+ | sum := ReduceLong(sn, Add); | ||
+ | Out.String('sum = '); Out.Int(sum); | ||
+ | |||
+ | mul := ReduceLong(sn, Mul); | ||
+ | | ||
+ | |||
+ | orderedNums[0] | ||
+ | | ||
+ | orderedNums[2] := 1; | ||
+ | |||
+ | greater := ReduceBool(orderedNums, Greater); | ||
+ | Out.String('greater = '); Out.Bool(greater); | ||
+ | |||
+ | less := ReduceBool(orderedNums, | ||
+ | Out.String(' | ||
+ | END Start; | ||
+ | |||
+ | END FunctionalCalculator. | ||
</ | </ | ||