一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - java語言注解基礎概念詳解

java語言注解基礎概念詳解

2021-03-11 14:27hypmxy Java教程

這篇文章主要介紹了java語言注解基礎概念詳解,具有一定借鑒價值,需要的朋友可以參考下。

1、RetentionPolicy.SOURCE:注解只保留在源文件,當Java文件編譯成class文件的時候,注解被遺棄;

2、RetentionPolicy.CLASS:注解被保留到class文件,但jvm加載class文件時候被遺棄,這是默認的生命周期;

3、RetentionPolicy.RUNTIME:注解不僅被保存到class文件中,jvm加載class文件之后,仍然存在;

這3個生命周期分別對應于:Java源文件(.java文件)--->.class文件--->內存中的字節碼。

那怎么來選擇合適的注解生命周期呢?

首先要明確生命周期長度SOURCE<CLASS<RUNTIME,所以前者能作用的地方后者一定也能作用。一般如果需要在運行時去動態獲取注解信息,那只能用RUNTIME注解;如果要在編譯時進行一些預處理操作,比如生成一些輔助代碼(如ButterKnife),就用CLASS注解;如果只是做一些檢查性的操作,比如@Override和@SuppressWarnings,則可選用SOURCE注解。

下面來介紹下運行時注解的簡單運用。

獲取注解

你需要通過反射來獲取運行時注解,可以從Package、Class、Field、Method...上面獲取,基本方法都一樣,幾個常見的方法如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/**
 * 獲取指定類型的注解
 */
public <A extends Annotation> A getAnnotation(Class<A> annotationType);
/**
 * 獲取所有注解,如果有的話
 */
public Annotation[] getAnnotations();
/**
 * 獲取所有注解,忽略繼承的注解
 */
public Annotation[] getDeclaredAnnotations();
/**
 * 指定注解是否存在該元素上,如果有則返回true,否則false
 */
public Boolean isAnnotationPresent(Class<? extends Annotation> annotationType);
/**
 * 獲取Method中參數的所有注解
 */
public Annotation[][] getParameterAnnotations();

要使用這些函數必須先通過反射獲取到對應的元素:Class、Field、Method等。

自定義注解

來看下自定義注解的簡單使用方式,這里先定義3個運行時注解:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
// 適用類、接口(包括注解類型)或枚舉
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface ClassInfo {
  String value();
}
// 適用field屬性,也包括enum常量
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface FieldInfo {
  int[] value();
}
// 適用方法
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface MethodInfo {
  String name() default "long";
  String data();
  int age() default 27;
}

這3個注解分別適用于不同的元素,并都帶有不同的屬性,在使用注解是需要設置這些屬性值。

再定義一個測試類來使用這些注解:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/**
 * 測試運行時注解
 */
@ClassInfo("Test Class")
public class TestRuntimeAnnotation {
    @FieldInfo(value = {1, 2})
      public String fieldInfo = "FiledInfo";
    @FieldInfo(value = {10086})
      public int i = 100;
    @MethodInfo(name = "BlueBird", data = "Big")
      public static String getMethodInfo() {
        return TestRuntimeAnnotation.class.getSimpleName();
    }
}

使用還是很簡單的,最后來看怎么在代碼中獲取注解信息:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/**
 * 測試運行時注解
 */
private void _testRuntimeAnnotation() {
    StringBuffer sb = new StringBuffer();
    Class<?> cls = TestRuntimeAnnotation.class;
    Constructor<?>[] constructors = cls.getConstructors();
    // 獲取指定類型的注解
    sb.append("Class注解:").append("\n");
    ClassInfo classInfo = cls.getAnnotation(ClassInfo.class);
    if (classInfo != null) {
        sb.append(Modifier.toString(cls.getModifiers())).append(" ")
                .append(cls.getSimpleName()).append("\n");
        sb.append("注解值: ").append(classInfo.value()).append("\n\n");
    }
    sb.append("Field注解:").append("\n");
    Field[] fields = cls.getDeclaredFields();
    for (Field field : fields) {
        FieldInfo fieldInfo = field.getAnnotation(FieldInfo.class);
        if (fieldInfo != null) {
            sb.append(Modifier.toString(field.getModifiers())).append(" ")
                      .append(field.getType().getSimpleName()).append(" ")
                      .append(field.getName()).append("\n");
            sb.append("注解值: ").append(Arrays.toString(fieldInfo.value())).append("\n\n");
        }
    }
    sb.append("Method注解:").append("\n");
    Method[] methods = cls.getDeclaredMethods();
    for (Method method : methods) {
        MethodInfo methodInfo = method.getAnnotation(MethodInfo.class);
        if (methodInfo != null) {
            sb.append(Modifier.toString(method.getModifiers())).append(" ")
                      .append(method.getReturnType().getSimpleName()).append(" ")
                      .append(method.getName()).append("\n");
            sb.append("注解值: ").append("\n");
            sb.append("name: ").append(methodInfo.name()).append("\n");
            sb.append("data: ").append(methodInfo.data()).append("\n");
            sb.append("age: ").append(methodInfo.age()).append("\n");
        }
    }
    System.out.print(sb.toString());
}

所做的操作都是通過反射獲取對應元素,再獲取元素上面的注解,最后得到注解的屬性值。

看一下輸出情況,這里我直接顯示在手機上:

java語言注解基礎概念詳解

總結

以上就是本文關于java語言注解基礎概念詳解的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

原文鏈接:http://blog.csdn.net/hypmxy/article/details/72676331

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲视频久久 | 午夜第九达达兔鲁鲁 | 国产高清精品自在久久 | 日本三级做a全过程在线观看 | 国产做a爰片久久毛片 | 国产日产韩产麻豆1区 | 婷婷在线观看香蕉五月天 | 国产在线精品亚洲第一区香蕉 | 青青青国产成人久久111网站 | 美女的隐私无遮挡撒尿 | 亚洲图片综合区 | 久久AV国产麻豆HD真实 | 亚洲 欧美 日本 国产 高清 | 午夜爽喷水无码成人18禁三级 | 国产麻豆流白浆在线观看 | 日本美女xx | 精品视频免费在线观看 | 精品午夜中文字幕熟女人妻在线 | 亚洲欧美另类在线观看 | 国内精品露脸在线视频播放 | 我的好妈妈7中字在线观看韩国 | 欧美高清日韩 | 国色天香社区在线 | 国产精品久久久久久久久 | 大象传媒2021秘密入口 | 亚洲日本久久一区二区va | 国语自产拍在线播放不卡 | 欧美亚洲另类在线观看 | 欧美激情 亚洲 | 被夫上司强迫中文 | 国产a免费| 温柔校草高h | 把老师操了 | 美女脱了内裤打开腿让你桶爽 | 精品国产91久久久久 | meyd–456佐山爱在线播放 | 国产精品国产三级在线专区 | 欧美夫妇野外交换hd高清版 | 国产在视频线在精品 | 亚洲国产成人在线 | 无码射肉在线播放视频 |