深入理解Java注解的使用方法
注解是jdk1.5新增的特性.大家都知道,jdk1.5在java的發(fā)展史上有著劃時代的意義.而注解的出現,在某種程度上顛覆了框架的設計.比如,spring在注解出現后,改善了原先五大組件的模式,增加了基于注解的實現方式.現在重點講講注解的使用.
元注解:
jdk1.5定義了4個元注解,元注解的作用是注解其他的注解.
1.@Retention
2.@Target
3.@Documented
4.@Inherited
@Retention用于指明該注解存在的時機.參數有三個值可選:RetentionPolicy.SOURCE,RetentionPolicy.CLASS,RetentionPolicy.RUNTIME可供選擇.分別表示:源碼中保留注解,字節(jié)碼文件中保留注解,運行時保留注解.
@Target用于指明注解能作用的范圍.比如參數中設置為ElementType.TYPE,表示作用于類和接口.如果你用來注解方法,則會發(fā)生編譯錯誤.由此可見它的功能是通過編譯器實現的.
@Documented表明該注解在使用javadoc工具生成開發(fā)文檔時,也會被納入進去.
@Inherited表明,某個位置使用該注解,那么在存在Java繼承關系的地方,該注解也能被繼承過來.這個可能不好理解.下面的代碼加以說明.
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE,ElementType.METHOD})
@Inherited
public @interface AnnoInherited {
}
測試代碼:
public class TestAnnoInherated {
public static void main(String[] args) {
Annotation[] annos=new Goo().getClass().getAnnotations();
for(Annotation a:annos){
System.out.println(a);
}
}
}
@AnnoInherited
class Foo{
}
class Goo extends Foo{
}
控制臺輸出:
@test.annotation.AnnoInherited()
上例中Goo前面并沒有加注解@AnnoInherited,但是父類Foo前面有,而@AnnoInherited加了元注解@Inherited,所以Foo能繼承過來.
自定義注解:
自定義注解的實例如下.
package test.annotation;
import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AnimalInfo {
String shout() default "";
//能不能看門
boolean isGuard() default true;
}
測試代碼:
public class TestAnimalInfo {
public static void main(String[] args) {
Animal animal=new Animal();
AnimalInfo info=animal.getClass().getAnnotation(AnimalInfo.class);
if(info!=null){
Annotation anno=info;//此處并沒有報錯.Annotation是一個接口.info是一個注解.這是因為編譯器會將注解編譯成接口,并且繼承了Annotation
System.out.println("Annotation類信息:"+Annotation.class);
System.out.println("AnimalInfo類信息:"+AnimalInfo.class);
Class[] cs=AnimalInfo.class.getInterfaces();
for(Class c:cs){
System.out.println(c); //AnimalInfo編譯后就是一個接口,并且繼承了Annotation,這里得到了證實.
}
System.out.println("info對象的類信息:"+info.getClass());
if("wangwang".equals(info.shout())&&info.isGuard()){
System.out.println("the animal is a dog");
}else if("miaomiao".equals(info.shout())&&!info.isGuard()){
System.out.println("the animal is a cat");
}else{
System.out.println("the animal is not a dog or cat");
}
}else{
System.out.println("it's not a animal");
}
}
}
@AnimalInfo(shout="wangwang",isGuard=true)
class Animal{
}
控制臺輸出:
Annotation類信息:interface java.lang.annotation.Annotation AnimalInfo類信息:interface test.annotation.AnimalInfo interface java.lang.annotation.Annotation info對象的類信息:class com.sun.proxy.$Proxy1 the animal is a dog
代碼分析:從控制臺可以看到.@AnimalInfo注解其實編譯后就是接口,并且它繼承了Annnotation.而通過反射獲得的注解實例,名字為$Proxy1,是一個類的對象.可見,該注解實例是JVM通過動態(tài)代理技術生成的.這也揭示了注解特性的底層實現原理.關于注解的具體底層技術原理,這里不再詳談.
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Java Fluent Mybatis實戰(zhàn)之構建項目與代碼生成篇上
Java中常用的ORM框架主要是mybatis, hibernate, JPA等框架。國內又以Mybatis用的多,基于mybatis上的增強框架,又有mybatis plus和TK mybatis等。今天我們介紹一個新的mybatis增強框架 fluent mybatis2021-10-10
Spring攔截器之HandlerInterceptor使用方式
這篇文章主要介紹了Spring攔截器之HandlerInterceptor使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
SpringCloud微服務之Hystrix組件實現服務熔斷的方法
微服務架構特點就是多服務,多數據源,支撐系統(tǒng)應用。這樣導致微服務之間存在依賴關系。這篇文章主要介紹了SpringCloud微服務之Hystrix組件實現服務熔斷的方法,需要的朋友可以參考下2019-08-08

