Prozedur (Programmierung)
Eine Prozedur ist in der Programmierung von Computersystemen eine benannte Folge von Anweisungen (möglicherweise mit Parametern), die es erlaubt, bestimmte Aufgaben in wiederverwendbarer Art zu formulieren. Man unterscheidet eigentlich
- offene Prozedur (Makro)
- geschlossene Prozedur (Unterprogramm)
Sowohl in der Theorie als auch in manchen Programmiersprachen wird unter Prozedur bzw. procedure einschränkend wie auch im Folgenden speziell ein Unterprogramm verstanden.
Im Unterschied zur Funktion liefert eine Prozedur keinen Rückgabewert auf direktem Weg.[1][2]
Im Allgemeinen kann eine Prozedur Aufrufparameter besitzen und auch die Werte von Variablen ändern. Man unterscheidet hier zwischen lokalen (nur innerhalb der Prozedur gültigen und von außen nicht beeinflussbaren) und globalen (außerhalb der Prozedur deklarierten) Variablen. Das Ändern globaler Variablen innerhalb einer Prozedur kann die Übersichtlichkeit des Programms beeinträchtigen und die Fehlersuche erschweren.
Prozeduren können wie Funktionen in Programmbibliotheken zusammengestellt werden. Hierdurch besteht die Möglichkeit, eine Prozedur auch aus anderen Programmen oder separaten Programmmodulen heraus aufzurufen. Durch die Möglichkeit, selbst Prozeduren und Bibliotheken erstellen zu können, kann der Programmierer den eigenen Code modular und wiederverwendbar gestalten.
Terminologie
Je nach Programmiersprache und Programmierparadigma gibt es Unterschiede in der Abgrenzung zwischen den Begriffen Funktion und Prozedur. FORTRAN77 beispielsweise fasst unter procedures Funktionen und prozedurale Unterprogramme (subroutines) zusammen.[3] In der Terminologie des C-Standards ist jedwedes Unterprogramm eine Funktion, unabhängig davon, ob ein Wert zurückgeliefert wird.[4] In der objektorientierten Programmierung werden beide Konzepte oft unter dem Sammelbegriff Methode zusammengefasst.
Prozedur als Unterprogramm
In der Programmierung tritt immer wieder der Fall auf, dass sich bestimmte Programmabschnitte wiederholen. Statt den Codeabschnitt jedes Mal zu kopieren, legt man ihn nur einmal an, versieht ihn mit einem Namen und ruft ihn an anderer Stelle über diesen Namen auf. Zur Laufzeit wird dann der betreffende Abschnitt durchlaufen. Einige Programmiersprachen (z. B. Pascal) unterscheiden bei der Deklaration explizit zwischen Funktion (mit Rückgabewert) und Prozedur (ohne Rückgabewert). In anderen Sprachen werden Prozeduren einfach als Funktionen oder Methoden ohne Rückgabewert realisiert. Im Gegensatz zur „reinen“ Funktion, deren einziger Effekt das nebenwirkungsfreie Liefern eines Wertes ist (z. B. Quadratwurzel einer Zahl), sind Prozeduren gerade wegen ihrer Nebeneffekte interessant, beispielsweise der Änderung von Speicherinhalten oder Ausgabeoperationen.
Beispiele
Die folgenden Beispiele definieren jeweils eine Prozedur zum Zeichnen einer Linie mit anzahl Punkten.
Pascal
In der Programmiersprache Pascal, die Prozeduren explizit als Sprachelement verwendet, gibt eine Prozedur im Gegensatz zu einer Funktion definitionsgemäß keinen Wert zurück:
Beispiel einer Prozedur in Pascal:
PROCEDURE Punkte_zeichnen(Anzahl:Integer);
VAR
i:Integer;
BEGIN
FOR i := 1 TO Anzahl DO
BEGIN
Write('.');
END;
END;
Beispiel eines Prozeduraufrufs in Pascal:
Punkte_zeichnen(5);
BASIC
Realisierung einer Prozedur in einer modernen BASIC-Variante (Subroutine ohne Rückgabewert):
Public Sub Punkte_zeichnen(anzahl As Integer)
For i As Integer = 1 To anzahl
Debug.print (".")
Next i
End Sub
Beispiel eines Methodenaufrufes in Basic:
Call Punkte_zeichnen(5)
C
Realisierung einer Prozedur in C. Das Schlüsselwort void
legt fest, dass die Funktion keinen Rückgabewert liefert:
void Punkte_zeichnen(int anzahl) {
for (int i = 0; i < anzahl; i++) {
putchar('.');
}
}
Beispiel eines Funktionsaufrufs in C:
Punkte_zeichnen(5);
Java
Realisierung einer Prozedur in Java (Methode ohne Rückgabewert):
public class Beispiel
{
public static void punkteZeichnen (int anzahl) {
for (int i = 0; i < anzahl; i++) {
System.out.print (".");
}
}
}
Beispiel eines Methodenaufrufs in Java:
Beispiel.punkteZeichnen(5);
Einzelnachweise
- ↑ Prozeduren-Funktionen-Methoden. (309 kB) Abgerufen am 20. September 2010 (PDF, Skript auf www.gdv.informatik.uni-frankfurt.de).
- ↑ Prozedurale Abstraktion, Funktionen. Abgerufen am 20. September 2010 (auf www.uni-koeln.de).
- ↑ FORTRAN77-Standard, Kap. 15. Abgerufen am 20. September 2010 (englisch).
- ↑ C99-Standard. (PDF; 3,8 MB) Abgerufen am 12. September 2010 (englisch, nicht-normatives Arbeitsdokument).