Java 註解

来源:https://www.cnblogs.com/jmcui/archive/2018/09/02/9574422.html
-Advertisement-
Play Games

一、概念和基本註解 從JDK1.5開始,引入了源代碼中的註解這一機制。註解使得 Java 源代碼中不但可以包含功能性的實現代碼,還可以包含元數據。 那麼什麼是元數據呢?所謂元數據,就是描述數據的數據。比如說一張圖片,圖片內容是它的主體數據,那麼像圖片的創建時間、修改時間、創建者等等這些數據,就是這張 ...


一、概念和基本註解

    從JDK1.5開始,引入了源代碼中的註解這一機制。註解使得 Java 源代碼中不但可以包含功能性的實現代碼,還可以包含元數據。

    那麼什麼是元數據呢?所謂元數據,就是描述數據的數據。比如說一張圖片,圖片內容是它的主體數據,那麼像圖片的創建時間、修改時間、創建者等等這些數據,就是這張圖片的元數據。

    那麼元數據有什麼用呢?我們可以用元數據來創建文檔、跟蹤代碼的依賴性和執行編譯時的格式檢查,並可以代替系統中原有的配置文件。

    Java 註解是 Java 代碼里的特殊標記,為我們在代碼中添加用 Java 程式無法表達的額外信息提供了一種格式化方法,使我們可以在編譯、類載入、運行時使用這些被註解修飾的程式元素(這些程式元素包括:類、屬性、方法等)。

    使用註解時要在其前面加上一個 “@” 符號,表明後面的內容為註解。

    在 Java 的 java.lang 包中,預定義了三個註解,它們分別是限定重寫父類方法的@Override、標記已過時的@Deprecated和抑制編譯器警告的@SuppressWarnings,通常稱這三個註解為內建註解或基本註解。

    @Override 在我們編程過程中經常遇到,就不細講了;@Deprecated 表示該類成員已經過時,在未來的版本中可能會被刪除,不建議使用。@SuppressWarnings 和前兩個註解有些不同,這個註解帶有一個屬性,表示要抑制什麼樣的警告信息,相關屬性值的含義如下:

@SuppressWarnings(value = "deprecation") //使用了過時的程式元素
@SuppressWarnings(value = "unchecked") //執行了未檢查的轉換
@SuppressWarnings(value = "unused") //有程式元素未被使用
@SuppressWarnings(value = "fallthrough") //switch 程式塊直接通往下一種情況,而沒有break
@SuppressWarnings(value = "path") //在類路徑中有不存在的路徑
@SuppressWarnings(value = "serial") //在可序列化的類上缺少 serialVersionUID 定義
@SuppressWarnings(value = "finally") //任何 finally 子句不能正常完成
@SuppressWarnings(value = "all") //所有情況

二、自定義註解

    註解之所以強大,能被眾多框架所使用的主要原因在於,它可以允許程式員自定義註解,使 Java 程式變成自描述的。註解的語法形式和介面差不多,只不過在 interface 前面多了一個 @ 符號。

    我們可以在自定義註解時定義屬性,在註解類型的定義中以無參方法的形式來聲明,其方法名和返回值分別定義了該屬性的名字和類型。另外需要註意的是,使用帶屬性的註解時,需要給屬性賦值,不過可以在定義註解時,給屬性賦預設值。

    Java中註解成員的類型必須是如下幾類: 

1. 基本數據類型(boolean, byte, char, short, int, long, float, double);
2. String;
3. Class;
4. 枚舉;
5. 其他的註解;
6. 以上類型的數組;

public @interface MyAnnotation {
      String name() default "張三";
      int age() default 22;
}

三、元註解

    上面提到了元數據——描述數據的數據。還有一個元註解的概念,即描述註解的註解——使用不同註解對註解進行註解。Java 為註解單獨提供了四種元註解,即@Target、@Retention、@Documented和@Inherited。下麵將分別介紹這四種元註解。

    1、@Target

    使用 @Target 註解的目的是用於指定被修飾的註解能用於修飾哪些程式元素。如果註解定義中不存在 @Target 元註解,則此註解可以用於任意程式元素上,如果存在這樣的元註解,則編譯器強制實施指定的使用規則。

/**
 * ElementType.ANNOTATION_TYPE : 限制此註解用於註解類
 * ElementType.CONSTRUCTOR : 限制此註解用於構造方法
 * ElementType.FIELD : 限制此註解用於欄位屬性(包括枚舉變數)
 * ElementType.LOCAL_VARIABLE : 限制此註解用於局部變數聲明
 * ElementType.METHOD : 限制此註解用於方法聲明
 * ElementType.PACKAGE : 限制此註解用於包聲明
 * ElementType.PARAMETER : 限制此註解用於參數聲明
 * ElementType.TYPE : 限制此註解用於類、介面(包括註解類型)或枚舉聲明
 */
@Target({ElementType.ANNOTATION_TYPE, ElementType.CONSTRUCTOR, ElementType.FIELD, ElementType.LOCAL_VARIABLE,
        ElementType.METHOD, ElementType.PACKAGE, ElementType.PARAMETER, ElementType.TYPE})
public @interface MyAnnotation {

}

    2、@Retention

    @Retention 用於指定被修飾的註解的生命周期,生命周期分為三種,分別是 RetentionPolicy.CLASS、RetentionPolicy.RUNTIME 和 RetentionPolicy.SOURCE。如果註解定義中不存在 @Retention 元註解,則生命周期預設為 RetentionPolicy.CLASS。

/**
 * RetentionPolicy.CLASS : 編譯器將把註解記錄在 class 文件中,當運行 Java 程式時,虛擬機不再保留註解。
 * RetentionPolicy.RUNTIME : 編譯器將把註解記錄在 class 文件中,當運行 Java 程式時,虛擬機保留註解,程式可以通過反射獲得該註解。
 * RetentionPolicy.SOURCE : 編譯器將直接丟棄被修飾的註解
 */
@Retention(RetentionPolicy.RUNTIME)
public @interface MyAnnotation {
      String name() default "張三";
      int age() default 22;
}
public class TestMyAnnotation {

    public static void main(String[] args) throws NoSuchMethodException, ClassNotFoundException {
        TestMyAnnotation testMyAnnotation = new TestMyAnnotation();
        testMyAnnotation.getObjectInfo();
    }

    @MyAnnotation
    @Deprecated
    public void getObjectInfo() throws ClassNotFoundException, NoSuchMethodException {
        Annotation[] annotations = Class.forName("annotation.TestMyAnnotation").getMethod("getObjectInfo").getAnnotations();
        for (Annotation annotation : annotations) {
            System.out.println("該註解是" + annotation);
            if (annotation instanceof MyAnnotation) {
                MyAnnotation myAnnotation = (MyAnnotation) annotation;
                System.out.println(myAnnotation.name());
                System.out.println(myAnnotation.age());
            }
        }
    }
    
}
TestMyAnnotation.java

    3、@Documented

    在預設的情況下,使用 javadoc 工具自動生成文檔時,註解將被忽略掉。如果想在文檔中也包含註解,必須使用 @Documented 註解。

@Documented
public @interface MyAnnotation {
}

    4、@Inherited

    預設情況下,父類的註解不被子類繼承,如果要想繼承父類註解,就必須使用  @Inherited 註解。

@Inherited
public @interface MyAnnotation {
}

四、總結

    其實,Java 註解可以簡單理解成一種標記符號、描述信息。強大的並不是註解本身,而是對註解的靈活使用。以 Spring 常見的  @Component 註解為例。Spring 在啟動時,上下文利用反射找到包路徑下帶有 @Component 的類,然後把它裝載成 Spring 的 Bean。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Maximum Multiple Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 3241 Accepted Submission(s): 134 ...
  • 1.Spring Boot簡介 wiki上的介紹: Spring Boot是Spring的常規配置解決方案,用於創建可以“運行”的獨立的,生產級的基於Spring的應用程式。[22]它預先配置了Spring對Spring平臺和第三方庫的最佳配置和使用的“見解視圖”,因此您可以儘量少開始。大多數Spr ...
  • 一 、前言 本文設計思想採用明德揚至簡設計法。VGA是最常見的視頻顯示介面,時序也較為簡單。本文從利用顯示屏通過VGA方式顯示測試圖案及靜態圖片著手帶大家接觸圖像顯示應用,算是為後續VGA顯示攝像頭採集圖像以及HDMI高清數字顯示方式打個基礎。 二、VGA顯示原理 關於VGA的詳細解釋可查看參考文獻 ...
  • 類載入機制中的雙親委派模型是非常重要的,本文從源碼的角度對雙親委派模式進行瞭解析,源碼調用基本邏輯很簡單. ...
  • 1.MyBatis架構(簡單介紹MyBatis的流程) 接下來簡單介紹一下這張圖:首先明確我們的目的就是要創建sqlsession然後利用這個對象去執行sql 完成CRUD。創建sqlsession的前提就是用session工廠去創建,利用工廠創建需要原材料啊,所以最頂端的MyBatis配置文件就是 ...
  • 1、非同步消息 當一個消息發送時候,消息會被交給消息代理,消息代理可以確保消息被髮送到指定的目的地,同時解放發送者,使其能夠繼續進行其它業務。消息代理通常有ActiveMQ、RabbitMQ...,目的地通常有隊列和主題,隊列採用點對點的模型,主題採用發佈訂閱模型 點對點模型:消息隊列可以有多個接受者 ...
  • 1、多線程安全問題 2、等待喚醒機制 ...
  • 給定兩個以字元串形式表示的非負整數 num1 和 num2,返回 num1 和 num2 的乘積,它們的乘積也表示為字元串形式。 示例 1: 示例 2: 說明: 從題目要求來看,應該是讓我們實現一個比較省記憶體的大數乘法,先分享幾個我在discuss中發現的不太切合題意的解法: 這個可以說是個毫無技術 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...