Смекни!
smekni.com

Procedures Parameters

Procedures, Parameters & Sub-Programs Essay, Research Paper

Procedures, Parameters & Sub-Programs

In any modern programming language, procedures play a vital role in the

construction of any new software. These days, procedures are used instead of

the old constructs of GOTO and GOSUB, which have since become obsolete.

Procedures provide a number of important features for the modern software

engineer:-

Programs are easier to write. Procedures save a large amount of time during

software development as the programmer only needs to code a procedure once, but

can use it a number of times. Procedures are especially useful in recursive

algorithms where the same piece of code has to be executed over and over again.

The use of procedures allows a large and complex program to be broken up into a

number of much smaller parts, each accomplished by a procedure. Procedures also

provide a form of abstraction as all the programmer has to do is know how to

call a procedure and what it does, not how it accomplishes the task.

Programs are easier to read. Procedures help to make programs shorter, and thus

easier to read, by replacing long sequences of statements with one simple

procedure call. By choosing goo procedure names, even the names of the

procedures help to document the program and make it easier to understand.

Programs are easier to modify. When repeated actions are replaced by one

procedure call, it becomes much easier to modify the code at a later stage, and

also correct any errors. By building up the program in a modular fashion via

procedures it becomes much easier to update and replace sections of the program

at a later date, if all the code for the specific section is in a particular

module.

Programs take less time to compile. Replacing a sequence of statements with

once simple procedure call usually reduces the compilation time of the program,

so long as the program contains more than one reference to the procedure!

Object programs require less memory. Procedures reduce the memory consumption

of the program in two ways. Firstly they reduce code duplication as the code

only needs to be stored once, but the procedure can be called many times.

Secondly, procedures allow more efficient storage of data, because storage for a

procedure’s variables is allocated when the procedure is called and deallocated

when it returns.

We can divide procedures into two groups:-

Function procedures, are procedures which compute a single value and whose calls

appear in expressions

For example, the procedure ABS is a function procedure, when given a number x,

ABS computes the absolute value of x; a call of ABS appears in an expression,

representing the value that ABS computes.

Proper procedures, are procedures whose calls are statements

For example, the procedure INC is a proper procedure. A call of INC is a

statement; executing INC changes the value stored in a variable.

Procedures have only one real disadvantage: Executing a procedure requires

extra time because of the extra work that must be done both when the procedure

is called, and when it returns.

Most of the time however, the advantages of using procedures heavily outweigh

this minor disadvantage.

Most procedures depend on data that varies from one call to the next, and for

this reason, Modula-2 allows a procedure heading to include a list of

identifiers that represent variables or expressions to supply when calling the

procedure. The programmer can use these identifiers, known as formal

parameters, in the body of the procedure in the same fashion as ordinary

variables.

A call of a procedure with parameters must include a list of actual parameters.

The number of actual parameters must be the same as the number of formal

parameters. Correspondence between the actual and formal parameters is by

position, so the first actual parameter corresponds to the first formal

parameter, the second actual parameter corresponds to the second formal

parameter, and so on. The type of each actual parameter must match the type of

the corresponding formal parameter.

Modula-2 provides to kinds of formal parameters:-

Variable parameters. In a procedure heading, if the reserved word VAR precedes

a formal parameter, then it is a variable parameter. Any changes made to a

variable parameter within the body of the procedure also affect the

corresponding actual parameter in the main body of the program.

Value parameters. If the reserved word VAR does not precede a formal parameter

then it is a value parameter. If a formal parameter is a value parameter, the

corresponding actual parameter is protected from change, no matter what changes

are made to the corresponding parameter in the procedure.

To sum up, variable parameters allow information to flow both into and/or out of

a procedure, whereas value parameters are one way and only allow information

into a procedure.

Most Modula-2 systems allow a program to “call” a program module as if it were a

procedure. We call a module used in this way a subprogram module or just a

subprogram. The commands for calling another program are not part of Modula-2

itself, but are provided by a procedure in a library module. The command used

in most Modula-2 systems for calling a sub-program is CALL, and a number of

parameters are usually passed along with this procedure so as to allow the two

programs to communicate with each other, but there is no way to supply

parameters to a subprogram. The parameters passed only indicate things like

whether the sub-program was executed correctly and did not terminate early

because of an error.

The primary reason for using subprograms is to reduce the amount of memory

required to execute a program. If a program is too large to fit into memory,

the programmer can often identify one or more modules, that need not exist

simultaneously. The main module can then call these modules as subprograms when

needed. Once a subprogram has completed execution, it returns control to the

main program, which can then call another sub program. All subprograms share

the same area of memory, and because only one is resident at a time, the memory

requirements of the overall program are greatly reduced.