<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Annotation_%28Java%29</id>
	<title>Annotation (Java) - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Annotation_%28Java%29"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Annotation_(Java)&amp;action=history"/>
	<updated>2026-05-16T13:29:01Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Annotation_(Java)&amp;diff=543235&amp;oldid=prev</id>
		<title>imported&gt;-haznK: /* growthexperiments-addlink-summary-summary:1|0|2 */</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Annotation_(Java)&amp;diff=543235&amp;oldid=prev"/>
		<updated>2024-12-18T15:07:32Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;growthexperiments-addlink-summary-summary:1|0|2&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Als &amp;#039;&amp;#039;&amp;#039;Annotation&amp;#039;&amp;#039;&amp;#039; wird im Zusammenhang mit der [[Programmiersprache]] [[Java (Programmiersprache)|Java]] ein Sprachelement bezeichnet, das die Einbindung von [[Metadaten#Metadaten in der Softwareentwicklung|Metadaten]] in den [[Quelltext]] erlaubt. Dieses Element wurde im [[Java Specification Request|JSR]] 175 festgelegt und mit der Version Java 5.0 eingeführt.&lt;br /&gt;
&lt;br /&gt;
Annotationen beginnen mit einem @-Zeichen. Daran schließt sich ihr Name an. Optional kann eine kommagetrennte Parameterliste folgen, die in runden Klammern eingefasst wird. Beispielsweise markiert die Annotation im folgenden Quelltextausschnitt die Klasse A als überholt ([[deprecated]]):&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Deprecated&lt;br /&gt;
public class A {}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Ein &amp;#039;&amp;#039;Annotation Processor&amp;#039;&amp;#039; ist ein Compiler-Plugin, das Annotationen beim Kompilieren auswerten kann, um damit Warnungen und Fehlermeldungen zu unterdrücken oder auszulösen oder weiteren Quellcode oder andere Dateien zu generieren. Mit Annotationen versehenen Code kann er jedoch nicht ändern. Annotationen, bei denen das vorgesehen ist, können auch zur Laufzeit mittels [[Reflexion (Programmierung)|Reflection]] ausgewertet werden.&lt;br /&gt;
&lt;br /&gt;
Eingesetzt werden Annotationen unter anderem im [[Jakarta EE|Jakarta-EE]]-Umfeld, um Klassen um Informationen zu erweitern, die vor Java 5 in separaten Dateien hinterlegt werden mussten. Prominente Beispiele sind Home- und Local-Interfaces sowie Deployment-Deskriptoren.&lt;br /&gt;
&lt;br /&gt;
Eine Vorgängertechnik zur Einbettung von Metadaten in Java-Quelltexten ist die Verwendung spezieller [[Javadoc]]-Kommentare. Diese wurden mit Hilfe sogenannter [[Doclet]]s ausgewertet. Ein vielfach eingesetztes Werkzeug für diese Methode ist [[XDoclet]]. Diese Technik kann auch nach Einführung der Annotationen weiterhin verwendet werden.&lt;br /&gt;
&lt;br /&gt;
== Vordefinierte Annotationstypen ==&lt;br /&gt;
&lt;br /&gt;
In [[Java Platform Standard Edition|Java SE 5.0]] stehen sieben vordefinierte Annotationstypen zur Verfügung, die in den Paketen ([[Java-Syntax#Pakete, Namen, Klassen, Schnittstellen|Package]]) &amp;lt;code&amp;gt;java.lang&amp;lt;/code&amp;gt; oder &amp;lt;code&amp;gt;java.lang.annotation&amp;lt;/code&amp;gt; liegen. Sie werden alle (im Gegensatz zu den meisten Annotationen) vom Compiler ausgewertet. Weitere können von Programmierern erstellt werden.&lt;br /&gt;
&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
! Annotation&lt;br /&gt;
! Beschreibung&lt;br /&gt;
|-&lt;br /&gt;
| colspan=&amp;quot;2&amp;quot; align=&amp;quot;left&amp;quot; | Im Paket &amp;lt;code&amp;gt;java.lang&amp;lt;/code&amp;gt; befinden sich Annotationen.&lt;br /&gt;
|-&lt;br /&gt;
|@Deprecated&lt;br /&gt;
|Hiermit können Klassen, Attribute oder Methoden gekennzeichnet werden, die nicht mehr verwendet werden sollen. Der Compiler gibt dann eine Warnung aus, wenn ein so gekennzeichnetes Element verwendet wird.&lt;br /&gt;
&lt;br /&gt;
Es empfiehlt sich zusätzlich, einen [[Javadoc]]-Kommentar anzubringen, der aufzeigt, wie das entsprechende Element ersetzt werden soll. Das folgende Beispiel zeigt dies:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
/**&lt;br /&gt;
 * @deprecated  Die Klasse A wurde mit Version 10.3 durch die Klasse ANeu ersetzt.&lt;br /&gt;
 */&lt;br /&gt;
@Deprecated&lt;br /&gt;
public class A {}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
|@Override&lt;br /&gt;
|Mit diesem Typ kann eine Methode gekennzeichnet werden, die die Methode ihrer Oberklasse überschreibt. Der Compiler stellt dann sicher, dass die Oberklasse diese Methode enthält und gibt einen Fehler aus, wenn dies nicht der Fall ist.&lt;br /&gt;
&lt;br /&gt;
Beispiel:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
public class A {&lt;br /&gt;
    public void eineMethode() {}&lt;br /&gt;
}&lt;br /&gt;
 &lt;br /&gt;
public class B extends A {&lt;br /&gt;
    @Override&lt;br /&gt;
    public void eineMethode() {}&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
|@SuppressWarnings&lt;br /&gt;
|Bei der Verwendung dieses Annotationstyps unterdrückt der Compiler bestimmte Warnungen. Der Annotation wird dazu ein Array mit Strings übergeben, die die zu unterdrückenden Warnungen enthalten.&lt;br /&gt;
&lt;br /&gt;
Im folgenden Beispiel wird der Compiler angewiesen, die &amp;#039;&amp;#039;deprecated&amp;#039;&amp;#039;-Warnung für die Klasse EineDeprecatedKlasse zu unterdrücken:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
&lt;br /&gt;
public class A {&lt;br /&gt;
    @SuppressWarnings({&amp;quot;deprecation&amp;quot;})&lt;br /&gt;
    public void eineMethode() {&lt;br /&gt;
        EineDeprecatedKlasse b = new EineDeprecatedKlasse();&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
|@SafeVarargs&lt;br /&gt;
|Mit dieser Annotation wird versichert, dass die Varargs-Parameter mit Generics nicht zur Laufzeit mit einem unpassenden Generics-Typ ersetzt werden. Beim Aufruf der Methode bzw. des Konstruktors wird dann keine Warnung angezeigt. Die Annotation wurde mit Java 7 eingeführt. Bis Java 6 konnte man beim Aufruf mit einer @SuppressWarnings-Annotation das Vertrauen in den aufgerufenen Code dokumentieren, ab Java 7 kann die Methode sich selbst als vertrauenswürdig deklarieren.&lt;br /&gt;
&lt;br /&gt;
|-&lt;br /&gt;
| colspan=&amp;quot;2&amp;quot; align=&amp;quot;left&amp;quot; | Im Paket &amp;lt;code&amp;gt;java.lang.annotation&amp;lt;/code&amp;gt; – diese werden nur für die Definition von Annotationen gebraucht.&lt;br /&gt;
|-&lt;br /&gt;
|@Documented&lt;br /&gt;
|Dieser Annotationstyp wird als Meta-Annotation verwendet: Eine Annotation dieses Typs legt für einen neu erstellten Annotationstyp fest, dass er von Javadoc bei der Erzeugung der Dokumentation berücksichtigt wird.&lt;br /&gt;
|-&lt;br /&gt;
|@Inherited&lt;br /&gt;
|Dieser Annotationstyp wird bei der Programmierung einer Annotation angewandt. Damit kann festgelegt werden, dass diese zusammen mit einer Klasse vererbt wird. Wird diese Annotation dann beispielsweise bei einer bestimmten Klasse angewendet, so gilt diese auch für alle Klassen, die von dieser erben.&lt;br /&gt;
|-&lt;br /&gt;
|@Retention&lt;br /&gt;
|Dieser Typ wird bei der Programmierung einer Annotation angewandt. Sie gibt an, wann auf sie selbst zugegriffen werden kann. Es gibt drei mögliche Werte für eine Annotation dieses Typs, die in der [[Aufzählungstyp|Enumeration]] &amp;lt;code&amp;gt;java.lang.annotation.RetentionPolicy&amp;lt;/code&amp;gt; aufgeführt sind:&lt;br /&gt;
;CLASS:Die Annotation wird mit der Klasse kompiliert und ist damit in der .class-Datei vorhanden. Allerdings kann sie nicht während der Laufzeit einer Anwendung ausgelesen werden. Dies ist der Standardwert.&lt;br /&gt;
;RUNTIME:Die Annotation kann während der Laufzeit einer Anwendung mittels des [[Reflexion (Programmierung)|Reflection-Mechanismus]] ausgelesen werden.&lt;br /&gt;
;SOURCE:Die Annotation wird vor dem Kompilieren aus dem Quelltext entfernt. Entsprechend steht sie zur Laufzeit eines Programms nicht zur Verfügung.&lt;br /&gt;
|-&lt;br /&gt;
|@Target&lt;br /&gt;
|Dieser Annotationstyp wird bei der Programmierung einer Annotation angewandt. Damit wird festgelegt, auf welche Elemente eines Programms sie angewendet werden darf. Die möglichen Werte für eine Annotation dieses Typs sind in der Enumeration &amp;lt;code&amp;gt;java.lang.annotation.ElementType&amp;lt;/code&amp;gt; aufgeführt.&lt;br /&gt;
;TYPE:Die Annotation kann nur auf Klassen, Interfaces oder Enumerations angewandt werden.&lt;br /&gt;
;FIELD:Die Annotation kann nur auf Felder angewandt werden.&lt;br /&gt;
;METHOD:Die Annotation kann nur auf Methoden angewandt werden. Konstruktoren sind dabei ausgeschlossen.&lt;br /&gt;
;PARAMETER:Die Annotation kann nur auf Parameter von Methoden und Konstruktoren angewandt werden.&lt;br /&gt;
;CONSTRUCTOR: Die Annotation kann nur auf Konstruktoren angewandt werden.&lt;br /&gt;
;LOCAL_VARIABLE: Die Annotation kann nur auf lokale Variablen angewandt werden.&lt;br /&gt;
;ANNOTATION_TYPE:Die Annotation kann nur auf Annotationen angewandt werden.&lt;br /&gt;
;PACKAGE: Die Annotation kann nur auf Paketen angewandt werden.&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
== Definition eigener Annotationen ==&lt;br /&gt;
&lt;br /&gt;
Annotationen sind spezielle Schnittstellen; ihre Namen werden daher konventionsgemäß mit großem Anfangsbuchstaben geschrieben. In ihrer Vereinbarung steht vor &amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;interface&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt; das Zeichen &amp;lt;code&amp;gt;@&amp;lt;/code&amp;gt;. Sie erweitern implizit die Schnittstelle &amp;lt;code&amp;gt;java.lang.annotation.Annotation&amp;lt;/code&amp;gt;. Sie dürfen keine andere Schnittstellen erweitern (d.&amp;amp;nbsp;h. &amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;extends&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt; ist verboten) und sind nicht generisch. Ihre Methoden sind parameterlos und nicht-generisch. Als Ergebnistypen (return type) sind nur folgende Typen erlaubt:&lt;br /&gt;
&lt;br /&gt;
* primitive Typen&lt;br /&gt;
* Aufzählungstypen (&amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;enum&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;)&lt;br /&gt;
* Annotationstypen&lt;br /&gt;
* &amp;lt;code&amp;gt;String&amp;lt;/code&amp;gt;&lt;br /&gt;
* &amp;lt;code&amp;gt;Class&amp;lt;/code&amp;gt;&lt;br /&gt;
* Felder (arrays) aus diesen Typen&lt;br /&gt;
&lt;br /&gt;
Sie werfen auch keine Ausnahmen und dürfen keine Rekursion verwenden.&lt;br /&gt;
&lt;br /&gt;
Viele Annotationen enthalten keine Methoden. Ein Beispiel wäre:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@interface Vorlaeufig { }&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Andere Annotationen enthalten (wie für Schnittstellen üblich) Methoden, allerdings nur mit den oben aufgeführten Ergebnistypen. Wenn eine Annotation nur eine Methode enthält, ist ihr Name konventionsgemäß &amp;lt;code&amp;gt;value&amp;lt;/code&amp;gt;:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@interface Test {&lt;br /&gt;
	boolean value(); // true solange nicht freigegeben&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
oder&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@interface Autoren {&lt;br /&gt;
	String[] value(); // Namen der Autoren&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
oder&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@interface Kunden {&lt;br /&gt;
	Person[] value();&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
wobei Person als Aufzählungstyp (&amp;lt;code&amp;gt;&amp;#039;&amp;#039;&amp;#039;enum&amp;#039;&amp;#039;&amp;#039;&amp;lt;/code&amp;gt;) oder Annotation definiert werden muss, z.&amp;amp;nbsp;B.:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;@interface Person {&lt;br /&gt;
	String name();&lt;br /&gt;
	int alter();&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Bei der Vereinbarung von Annotationen werden häufig die Standard-Annotationen aus dem Paket &amp;lt;code&amp;gt;java.lang.annotation&amp;lt;/code&amp;gt; verwendet. Insbesondere soll mit &amp;lt;code&amp;gt;@Retention&amp;lt;/code&amp;gt; angegeben werden, wie lange die Annotation aufbewahrt werden soll: nur im Quelltext (&amp;lt;code&amp;gt;SOURCE&amp;lt;/code&amp;gt;), in der gespeicherten class-Datei (&amp;lt;code&amp;gt;CLASS&amp;lt;/code&amp;gt;) oder auch in der geladenen Klasse (&amp;lt;code&amp;gt;RUNTIME&amp;lt;/code&amp;gt;). &amp;lt;code&amp;gt;@Target&amp;lt;/code&amp;gt; beschreibt, für welche Programmelemente die Annotation verwendet werden darf. Beispielsweise sind alle Annotationsvereinbarungen im Paket &amp;lt;code&amp;gt;java.lang.annotation&amp;lt;/code&amp;gt; mit den Annotationen&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Documented&lt;br /&gt;
@Retention(value=RUNTIME)&lt;br /&gt;
@Target(value=ANNOTATION_TYPE)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
versehen. Hierdurch werden sie alle von javadoc ausgewertet, im [[Bytecode]] mit geladen und können so zur Laufzeit ausgewertet werden; außerdem dürfen sie nur für Annotationstypen verwendet werden.&lt;br /&gt;
&lt;br /&gt;
== Verwendung eigener Annotationen ==&lt;br /&gt;
Eine Annotation ohne Methoden, wie &amp;lt;code&amp;gt;@Vorlaeufig&amp;lt;/code&amp;gt;, kann z.&amp;amp;nbsp;B. einer Klasse vorangestellt werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Vorlaeufig&lt;br /&gt;
class Klasse {&lt;br /&gt;
	void methode();&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Einer Annotation mit nur einer Methode mit dem Namen &amp;lt;code&amp;gt;value&amp;lt;/code&amp;gt; muss in Klammern ein konstanter Wert vom Ergebnistyp dieser Methode mit angegeben werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Test(true)&lt;br /&gt;
public void methode() { ... }&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Wenn der Ergebnistyp ein Array ist, soll ein Arrayliteral verwendet werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Autoren({&amp;quot;Solymosi&amp;quot;, &amp;quot;Grude&amp;quot;})&lt;br /&gt;
String buch = &amp;quot;Algorithmen und Datenstrukturen mit Java&amp;quot;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Wenn das Array keine Elemente enthält, muss &amp;lt;code&amp;gt;({})&amp;lt;/code&amp;gt; mit angegeben werden. Wenn das Array jedoch nur ein Element enthält, können die geschweiften Klammern weggelassen werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Autoren(&amp;quot;Solymosi&amp;quot;)&lt;br /&gt;
String anderesBuch = &amp;quot;Programmieren in Scala&amp;quot;&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Einer Annotation mit mehreren Methoden muss jeder ihrer Methoden in Klammern ein konstanter Wert zugewiesen werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Person(name = &amp;quot;Andreas Solymosi&amp;quot;, alter = 56)&lt;br /&gt;
Konto konto = new Konto();&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Die Möglichkeit, den Wert mit dem Namen anzugeben, besteht auch für Annotationen mit einer Methode (ist allerdings überflüssig, dient höchstens der Lesbarkeit):&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Test(value = true)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
Eine komplexe (geschachtelte) Annotation muss geschachtelt angewendet werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Kunden(@Person(name = &amp;quot;Andreas Solymosi&amp;quot;, alter = 56))&lt;br /&gt;
class Unternehmen { … }&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
In der Vereinbarung der Annotation können für die Methoden Standardwerte definiert werden; dann kann der entsprechende Wert bei der Verwendung weggelassen werden. Da Annotationen Schnittstellen sind, können sie selber mit Annotationen markiert werden:&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
@Autoren(&amp;quot;Solymosi&amp;quot;)&lt;br /&gt;
public @interface Test {&lt;br /&gt;
	boolean wert() default false; // muss nicht unbedingt wert heißen&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Auswertung von Annotationen ==&lt;br /&gt;
&lt;br /&gt;
Wenn die Annotationen mit dem Bytecode der Klasse geladen werden, können sie mit Hilfe von Reflexion ausgewertet werden. Beispielsweise kann man feststellen, ob eine Annotation angegeben wurde oder nicht:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;boolean&amp;#039;&amp;#039;&amp;#039; istVorlaeufig = Klasse.&amp;#039;&amp;#039;&amp;#039;class&amp;#039;&amp;#039;&amp;#039;.isAnnotationPresent(Vorlaeufig.&amp;#039;&amp;#039;&amp;#039;class&amp;#039;&amp;#039;&amp;#039;);&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Wenn man festgestellt hat, dass die Annotation vorhanden ist, dann kann man auch ihren Wert lesen, z.&amp;amp;nbsp;B. ob die Methode noch im Testzustand ist oder nicht:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
Test test = Klasse.&amp;#039;&amp;#039;&amp;#039;class&amp;#039;&amp;#039;&amp;#039;.getMethod(&amp;quot;methode&amp;quot;, &amp;#039;&amp;#039;&amp;#039;new&amp;#039;&amp;#039;&amp;#039; Class[]{}).getAnnotation(Test.&amp;#039;&amp;#039;&amp;#039;class&amp;#039;&amp;#039;&amp;#039;).value();&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Wenn hierbei die Annotation nicht vorhanden ist, wird von &amp;lt;code&amp;gt;getAnnotation()&amp;lt;/code&amp;gt; die Ausnahme &amp;lt;code&amp;gt;NullPointerException&amp;lt;/code&amp;gt; ausgelöst.&lt;br /&gt;
Aus einer komplexen Annotation müssen ihre Elemente einzeln selektiert werden:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;code&amp;gt;&lt;br /&gt;
Person kunden = Unternehmen.&amp;#039;&amp;#039;&amp;#039;class&amp;#039;&amp;#039;&amp;#039;.getAnnotation(Kunden.&amp;#039;&amp;#039;&amp;#039;class&amp;#039;&amp;#039;&amp;#039;).value()[0];&lt;br /&gt;
&amp;lt;/code&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Annotation von Paketen ==&lt;br /&gt;
Die &amp;#039;&amp;#039;Java Language Specification&amp;#039;&amp;#039; erlaubt auch die Annotation von Paketen, beispielsweise um Dokumentation zu einem Paket bereitzustellen. Pro Paket darf maximal eine &amp;lt;code&amp;gt;package&amp;lt;/code&amp;gt;-Deklaration mit Annotationen versehen sein. Falls ein Paket Annotationen erhalten soll, empfiehlt die &amp;#039;&amp;#039;Java Language Specification&amp;#039;&amp;#039;, eine gesonderte Datei namens &amp;lt;code&amp;gt;package-info.java&amp;lt;/code&amp;gt; im Verzeichnis dieses Pakets anzulegen. Diese Datei beinhaltet dann die &amp;lt;code&amp;gt;package&amp;lt;/code&amp;gt;-Deklaration mit den Annotationen.&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [http://public.beuth-hochschule.de/~solymosi/veroeff/Annotationen.html Annotationen in Java]&lt;br /&gt;
* [http://docs.oracle.com/javase/tutorial/java/annotations/ Annotations] in Suns Java-Tutorial (englisch)&lt;br /&gt;
* [http://docs.oracle.com/javase/1.5.0/docs/guide/apt/index.html Annotation Processing Tool (apt)] (englisch)&lt;br /&gt;
* [http://docs.oracle.com/javase/1.5.0/docs/guide/language/annotations.html The J2SE 5.0 Annotations Feature] bei Sun (englisch)&lt;br /&gt;
* [http://jcp.org/en/jsr/detail?id=175 JSR 175: A Metadata Facility for the JavaTM Programming Language] (englisch)&lt;br /&gt;
* [http://docs.oracle.com/javase/specs/jls/se8/html/jls-9.html#jls-9.7 Annotations] in der [[Java Language Specification]] (englisch)&lt;br /&gt;
* [https://openbook.rheinwerk-verlag.de/javainsel/10_008.html#u10.8 Annotationen] in „Java ist auch eine Insel“&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Java (Programmiersprache)]]&lt;/div&gt;</summary>
		<author><name>imported&gt;-haznK</name></author>
	</entry>
</feed>