您好,登錄后才能下訂單哦!
這篇文章主要介紹了Java注解怎么自定義和使用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Java注解怎么自定義和使用文章都會有所收獲,下面我們一起來看看吧。
注解
叫元數據,一種代碼級別的說明,它是JDK1.5及以后版本引入的一個特性,與類、接口、枚舉在同一個層次,它可以聲明在包、類、字段、局部變量、方法參數等的前面,用來對這些元素進行說明、注釋。
注解的作用分類
編寫文檔:通過代碼里表示的元數據生成文檔【生成doc文檔】
代碼分析:通過代碼里表示的元數據進行分析【使用反射】
編譯檢查:通過代碼里表示的元數據讓編譯器能夠實現基本的編譯檢查【Override】
注解按照運行機制分類
源碼注解:注解只在源碼中存在,編譯成.class文件之后就不存在了
編譯時注解:注解在源碼存在的基礎上,也會在.class文件中存在,但是在運行階段中就不存在了,例如:@Override
運行時注解:注解在運行階段依然存在,且能夠影響程序的運行過程,例如:@Autowired
(1)注解:用于描述代碼,說明程序,主要目的是為了給計算機看,且能夠影響程序的運行。
(2)注釋:用于描述代碼的作用和一些關鍵性的知識點,使用文字描述程序,是為了給程序員觀看,以此來使程序員能夠以最快的時間了解被注釋的代碼。
@Override:檢測該注解標記的方法是否繼承自父類;
@Deprecated:說明被標記的內容已過時,暗示著在不久之后可能會被更新抹除;
@SuppressWarnings:壓制警告,就是被標記的部分不會產生警告,常用的參數:@SuppressWarnings(“all”);
@SafeVarargs:參數安全類型注解,它的目的就是提醒開發者不要用參數做一些不安全的操作,它的存在會阻止編譯器產生unchecked這樣的警告;
元注解:用于描述注解的注解,在創建注解時使用
1. @Target屬性值:
ElementType.TYPE:能修飾類、接口或枚舉類型
ElementType.METHOD:能修飾方法
ElementType.FIELD: 能修飾成員變量
ElementType.PARAMETER:能修飾參數
ElementType.CONSTRUCTOR:能夠修飾構造器
ElementType.ANNOTATION_TYPE:能夠修飾注解
ElementType.PACKAGE:能夠修飾包
ElementType.LOCAL_VARIABLE:能夠修飾局部變量
2.@Retention屬性值:
RetentionPolicy.SOURCE:注解只在源碼中存在,編譯成class之后就沒了
RetentionPolicy.CLASS:注解在源碼和class中都存在,運行時就沒了,這個是Retention的默認值
RetentionPolicy.RUNTIME: 注解在源碼、class、運行時都存在,如果要使用反射一定要定義為這種類型
3.@Documented:該注解的作用就是表示此注解標記的注解可以包含到javadoc文件中去
4.@Inherited:描述注解是否能夠被子類所繼承
1.格式:
@Inherited//元注解public @interface zhujie{}
2.注解本質:注解的本質上就是一個接口,該接口默認繼承Annotation
public interface MyAnno extends java.lang.annotation.Annotion
3.屬性:接口中可以定義的內容(成員方法、抽象方法)
屬性的返回值:
八種基本數據類型
字符串類、接口、枚舉
注解
以上類型的數組
屬性賦值注意事項
如果定義屬性時,使用default關鍵字給屬性默認初始化值,則使用注解時,就可以不進行屬性的賦值,否則都必須給屬性賦值
如果只有一個屬性需要賦值的話,并且屬性的名稱是value,則使用注解給屬性賦值時,value可以省略,直接定義值就可以了
數組賦值時,值需要使用{}包裹,如果數組中只有一個值,則{}可以省略不寫
自定義注解annotation
@Retention(value = RetentionPolicy.RUNTIME)
@Target(value = ElementType.TYPE)
public @interface annotation {
String name() default "木魚";
int age();
int[] score();
}
使用以上注解的類TestAnnotation
//name具有默認值,不需要必須為name賦值,但也可以重新賦值
@annotation(age=20,score={99,100,100})
public class TestAnnotation {
public static void main(String[] args) throws ClassNotFoundException {
Class clazz = Class.forName("test.TestAnnotation");
annotation annotation = (annotation) clazz.getAnnotation(annotation.class);
System.out.println("姓名:"+annotation.name()+" 年齡:"+annotation.age());
System.out.print("成績為:");
int[] score=annotation.score();
for (int score1:score){
System.out.print(score1+" ");
}
}
}
兩個方法:
類對象調用 isAnnotationPresent(Class<? extends Annotation> annotationClass)
判斷是否應用了某個注解
通過getAnnotation()方法獲取Annotation對象,或者getAnnotations()方法獲取所有應用在該類上的注解
1.創建自定義注解
@Retention(value = RetentionPolicy.RUNTIME)
@Target(value = ElementType.FIELD)
public @interface StringNull {
}
2.創建實體類
public class Student {
@StringNull
public String name=null;
@StringNull
public String xuehao=null;
@StringNull
public String sex=null;
public void setName(String name) {
this.name = name;
}
public void setXuehao(String xuehao) {
this.xuehao = xuehao;
}
public void setSex(String sex) {
this.sex = sex;
}
}
3.創建測試類,測試注解
public class TestAnnotation {
public static void main(String[] args) throws Exception{
Class clazz = Class.forName("test.Student");
Student student =(Student) clazz.newInstance();
student.setName("小明");
Field[] fields= clazz.getFields();
for(Field f:fields){
if(f.isAnnotationPresent(StringNull.class)){
if(f.get(student)==null){
System.out.println(f.getName()+":是空的字符串屬性");
}else{
System.out.println(f.getName()+":"+f.get(student));
}
}
}
}
}
關于“Java注解怎么自定義和使用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Java注解怎么自定義和使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。