前言
目前,越來越多的架構設計在使用註解,例如spring3.0、struts2等框架。讓我們先來看看註解的定義。如下是一段使用了JDK 5 Annotation @Target的代碼:
@Target({ElementType.METHOD})@Retention(RetentionPolicy.RUNTIME)@Inherited@Documentedpublic @interface AsynLog { }一、@Target的用法
java.lang.annotation.Target
用於設定註解使用範圍
java.lang.annotation.ElementType
Target通過ElementType來指定註解可使用範圍的枚舉集合
二、ElementType的用法
| 取值 | 註解使用範圍 |
| METHOD | 可用於方法上 |
| TYPE | 可用於類或者接口上 |
| ANNOTATION_TYPE | 可用於註解類型上(被@interface修飾的類型) |
| CONSTRUCTOR | 可用於構造方法上 |
| FIELD | 可用於域上 |
| LOCAL_VARIABLE | 可用於局部變量上 |
| PACKAGE | 用於記錄java文件的package信息 |
| PARAMETER | 可用於參數上 |
這裡重點說明下:ElementType. PACKAGE。它並不是使用在一般的類中,而是用在固定的文件package-info.java中。這裡需要強調命名一定是“package-info”。由於package-info.java並不是一個合法的類,使用eclipse創建類的方式會提示不合法,所以需要以創建文件的方式來創建package-info.java。
例如,定義可使用範圍PACKAGE:
@Target({ElementType.PACKAGE,ElementType.METHOD})@Retention(RetentionPolicy.RUNTIME)@Inherited@Documentedpublic @interface AsynLog { }那麼,創建文件:package-info.java,內容如下:
複製代碼代碼如下:
@AsynLog
package org.my.commons.logs.annotation;
重點說明:註解只能在ElementType設定的範圍內使用,否則將會編譯報錯。例如:範圍只包含ElementType.METHOD ,則表明該註解只能使用在類的方法上,超出使用範圍將編譯異常。