Java在1.5開始引入了註解,目前流行的框架都在用註解,可想而知註解的強大之處。
以下通過自定義註解來深入瞭解java註解。
一、創建自定義註解
package com.sam.annotation;
import java.lang.annotation.*;
/**
* @author sam
* @since 2017/7/13
*/
@Target({ElementType.METHOD, ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Inherited
@Documented
public @interface MyMessage {
String name() default "sam";
int num() default 0;
String desc();
}
說明:
- Target:指明註解支持的使用範圍,取值可以參考枚舉ElementType,以下:
- ElementType.TYPE //類、接口、枚舉
- ElementType.FIELD //屬性
- ElementType.METHOD //方法
- ElementType.PARAMETER //參數
- ElementType.CONSTRUCTOR //構造器
- ElementType.LOCAL_VARIABLE //局部變量
- ElementType.ANNOTATION_TYPE //註解
- ElementType.PACKAGE //包
- Retention:指明註解保留的的時間長短,取值參考枚舉RetentionPolicy,一下:
- SOURCE //源文件中保留
- CLASS //class編譯時保留
- RUNTIME //運行時保留
- Inherited:指明該註解類型被自動繼承。如果一個annotation註解被@Inherited修飾,那麼該註解作用於的類 的子類也會使用該annotation註解。
- Documented:指明擁有這個註解的元素可以被javadoc此類的工具文檔化。
二、創建測試類,使用自定義註解
package com.sam.annotation;
/**
* @author sam
* @since 2017/7/13
*/
public class AnnotationTest {
@MyMessage(num = 10, desc = "參數a")
private static int a;
@MyMessage(name = "Sam test", desc = "測試方法test")
public void test() {
System.out.println("test");
}
}
在該類中的屬性和方法,使用了自定義的註解,並指明瞭參數。
那麼現在就需要解析自定義的註解。
三、解析註解
使用反射機制處理自定義註解
package com.sam.annotation;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
/**
* 使用反射處理註解
*
* @author sam
* @since 2017/7/13
*/
public class MyMessageProcessor {
public static void main(String[] args) {
try {
Class clazz = MyMessageProcessor.class.getClassLoader().loadClass("com.sam.annotation.AnnotationTest");
Field[] fields = clazz.getDeclaredFields();
for (Field field : fields) {
MyMessage myMessage = field.getAnnotation(MyMessage.class);
System.out.println("name:" + myMessage.name() + " num:" + myMessage.num() + " desc:" + myMessage.desc());
}
Method[] methods = clazz.getMethods();
for (Method method : methods) {
if (method.isAnnotationPresent(MyMessage.class)) {
MyMessage myMessage = method.getAnnotation(MyMessage.class);
System.out.println("name:" + myMessage.name() + " num:" + myMessage.num() + " desc:" + myMessage.desc());
}
}
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
運行MyMessageProcessor 得到結果:
name:sam num:10 desc:參數a
name:Sam test num:0 desc:測試方法test
Process finished with exit code 0
具體定製註解所實現的內容,可以在MyMessageProcessor.java中進行修改。
自此,已經對java的自定義註解有簡單的瞭解。