Zugriffsfunktion

aus Wikipedia, der freien Enzyklopädie
Zur Navigation springen Zur Suche springen

Eine Zugriffsfunktion, auch Zugriffsmethode, Akzessor oder im Programmiererjargon getter und setter genannt, ist in der objektorientierten Programmierung eine spezielle Methode, die eine einzelne Eigenschaft (Attribut) eines Objekts abfragt oder ändert. Zugriffsfunktionen sind Teil der öffentlichen Schnittstelle eines Objekts und verbergen Implementierungsdetails dieses Objekts. Dadurch kann die Implementierung eines Objekts geändert werden, ohne seine öffentliche Schnittstelle zu ändern.

Abfragemethoden (Getter)

[Bearbeiten | Quelltext bearbeiten ]

Eine Zugriffsmethode, die eine Eigenschaft eines Objekts abfragt, heißt auch Abfragemethode oder Getter (von englisch to get – etwas holen). Die Eigenschaft kann entweder direkt aus einem Objektattribut entnommen, das dann normalerweise eine geringere Sichtbarkeit hat, oder im Moment des Aufrufs berechnet werden. Für den Aufrufer ist das nicht erkennbar, dadurch wird die Kapselung sichergestellt.

In einigen Programmiersprachen ist es üblich, die Namen aller Abfragemethoden mit get beginnen zu lassen. So könnte z. B. eine Methode, die den Namen einer Person abfragt, getName heißen. Alternativ können Methoden, welche Boolesche Werte abfragen, mit is (z. B. isMarried) oder has (z. B. hasChild) beginnen.

In anderen Programmiersprachen ist dies unüblich und die Methode hieße einfach name, da bereits der Funktionsaufruf als solcher ein Holen in sich hat.

Änderungsmethoden (Setter)

[Bearbeiten | Quelltext bearbeiten ]

Eine Zugriffsmethode, die ein Objektattribut ändert, heißt auch Änderungsmethode oder Setter (von englisch to set – etwas einstellen, setzen). Ein Vorteil der Änderungsmethode besteht darin, dass sie vor der Änderung den Wert auf Gültigkeit prüfen kann. So könnte beispielsweise in einem Objekt, das eine Person darstellt, die Funktion zum Setzen des Namens sicherstellen, dass als Name kein leerer Text übergeben wird. Falls ein ungültiger Wert übergeben wird, besteht eine mögliche Reaktion im Auslösen einer Ausnahmeroutine, wodurch der normale Programmablauf unterbrochen und ein Fehler signalisiert wird.

Ein weiterer Vorteil der Änderungsmethode besteht darin, dass sie eventuelle Beobachter (im Sinne des gleichnamigen Entwurfsmusters) über die Änderung des Objektzustands informieren kann. Dies wird beispielsweise in Model-View-Controller-Architekturen benutzt, um eine Sicht (View, z. B. ein Bildschirmformular) zu aktualisieren, wenn der Inhalt des zugrundeliegenden Modells (Model, z. B. ein Datensatz in einer Datenbanktabelle) geändert wurde.

In einigen Programmiersprachen ist es üblich, die Namen aller Änderungsmethoden mit set beginnen zu lassen. So könnte z. B. eine Methode, die den Namen einer Person ändert, setName heißen. In anderen Programmiersprachen ist dieses Präfix unüblich und die Methode hieße einfach name, da bereits der parametrisierte Funktions-/Prozeduraufruf als solcher eine setzende Methode impliziert.

JavaBeans, die Komponenten der Programmiersprache Java, erkennen Zugriffsfunktionen zur Laufzeit per Reflection anhand ihrer Präfixe get und set. Die eigens dafür bereitgestellte Klasse java.beans.Introspector leitet daraus dann automatisch den Namen der abgefragten oder geänderten Eigenschaft ab, also beispielsweise saldo aus getSaldo oder geburtstag aus setGeburtstag.[1]

Martin Fowler weist in seiner Beschreibung des Antimusters Anämisches Objektmodell darauf hin, dass Objektmodelle, deren Objekte praktisch nur aus Zugriffsfunktionen bestehen und kein darüber hinausgehendes Verhalten anbieten, keine Vorteile gegenüber klassischen Datenmodellen haben. Solche Objektmodelle sind daher nicht unbedingt sinnvoll.[2]

Einzelnachweise

[Bearbeiten | Quelltext bearbeiten ]
  1. Graham Hamilton (Hrsg.): Java Beans API specification. Sun Microsystems, Inc., 8. August 1997, S. 54 (online – Version 1.01). 
  2. Martin Fowler: AnemicDomainModel. In: MF Bliki. 25. November 2003, abgerufen am 25. März 2009 (englisch). 
Abgerufen von „https://de.wikipedia.org/w/index.php?title=Zugriffsfunktion&oldid=219696836"