Java注解是Java語言提供的一種用于表示元數據的標記,它們可以被添加到Java源代碼中的各種元素中,如類、方法、變量甚至是包。Java注解在編譯器、運行時和工具處理程序中都可以使用來實現一些特殊的功能,比如生成文檔、代碼編譯和檢查、單元測試等。Java注解通常以@開頭,例如@Deprecated、@Override和@SuppressWarnings等。
Java注解的語法相對簡單,在注解名稱前加上@符號即可,例如下面的代碼示例:
/** * 注解示例 */ @MyAnnotation public class MyClass { // code here }
當然,我們也可以自定義Java注解來實現我們的特殊需求。自定義Java注解需要使用Java注解元素提供的四種元注解之一,分別是@Target、@Retention、@Documented和@Inherited。其中,@Target指定注解的作用目標(ElementType),如類、方法、字段等;@Retention指定注解的生命周期(RetentionPolicy),如源代碼、字節碼或者運行時。@Documented用于指定該注解是否包含在JavaDoc文檔中,而@Inherited用于指定該注解是否可以被繼承。
下面就是一個自定義注解的代碼示例,其中我們定義了一個@MyAnnotation注解,該注解可以用于類、方法和屬性,并且設置了三個屬性:name、age和score:
/** * 自定義注解示例 */ @Target({ ElementType.TYPE, ElementType.METHOD, ElementType.FIELD }) @Retention(RetentionPolicy.RUNTIME) @Inherited @Documented public @interface MyAnnotation { String name() default "unknown"; int age(); double score(); }
使用自定義注解也很簡單,只需要在Java源代碼中對應的類、方法或屬性上使用@MyAnnotation注解并指定相應的屬性值即可:
/** * 使用@MyAnnotation注解的Java類 */ @MyAnnotation(name = "Tom", age = 18, score = 90.5) public class MyTest { @MyAnnotation(name = "Mike", age = 20, score = 85.0) private String name; @MyAnnotation(age = 22, score = 95.0) public void show() { // code here } }
在這個例子中,我們分別對類、方法和屬性分別使用了@MyAnnotation注解,并指定了相應的屬性值。這樣,在編譯器、運行時或者其他工具程序中我們就可以使用這些注解來實現我們自己的特殊需求了。