国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java 中的注解詳解及示例代碼

2019-11-26 13:54:17
字體:
來源:轉載
供稿:網友

在Java中,注解(Annotation)引入始于Java5,用來描述Java代碼的元信息,通常情況下注解不會直接影響代碼的執行,盡管有些注解可以用來做到影響代碼執行。

注解可以做什么

Java中的注解通常扮演以下角色

  1. 編譯器指令
  2. 構建時指令
  3. 運行時指令

其中

  1. Java內置了三種編譯器指令,本文后面部分會重點介紹
  2. Java注解可以應用在構建時,即當你構建你的項目時。構建過程包括生成源碼,編譯源碼,生成xml文件,打包編譯的源碼和文件到JAR包等。軟件的構建通常使用諸如Apache Ant和Maven這種工具自動完成。這些構建工具會依照特定的注解掃描Java代碼,然后根據這些注解生成源碼或文件。
  3. 通常情況下,注解并不會出現在編譯后的代碼中,但是如果想要出現也是可以的。Java支持運行時的注解,使用Java的反射我們可以訪問到這些注解,運行時的注解的目的通常是提供給程序和第三方API一些指令。

注解基礎

一個簡單的Java注解類似與@Entity。其中@的意思是告訴編譯器這是一個注解。而Entity則是注解的名字。通常在文件中,寫法如下

public @interface Entity {
}

注解元素

Java注解可以使用元素來進行設置一些值,注解中的元素類似于屬性或者參數。定義包含元素的注解示例代碼

public @interface Entity {
  String tableName();
}

使用包含元素的注解示例代碼

@Entity(tableName = "vehicles")

上述注解的元素名稱為tableName,設置的值為vehicles。沒有元素的注解不需要使用括號。

如果注解包含多個元素,使用方法如下

@Entity(tableName = "vehicles", primaryKey = "id")

如果注解只有一個元素,通常我們的寫法是這樣的

@InsertNew(value = "yes")

但是這種情況下,當且僅當元素名為value,我們也可以簡寫,即不需要填寫元素名value,效果如下

@InsertNew("yes")

注解使用

注解可以用來修飾代碼中的這些元素

  1. 接口
  2. 方法
  3. 方法參數
  4. 屬性
  5. 局部變量

一個完整的使用示例如下

@Entitypublic class Vehicle {  @Persistent  protected String vehicleName = null;  @Getter  public String getVehicleName() {    return this.vehicleName;  }  public void setVehicleName(@Optional vehicleName) {    this.vehicleName = vehicleName;  }  public List addVehicleNameToList(List names) {    @Optional    List localNames = names;    if(localNames == null) {      localNames = new ArrayList();    }    localNames.add(getVehicleName());    return localNames;  }}

內置的Java注解

Java中有三種內置注解,這些注解用來為編譯器提供指令。它們是

  1. @Deprecated
  2. @Override
  3. @SuppressWarnings

@Deprecated

可以用來標記類,方法,屬性。
如果上述三種元素不再使用,使用@Deprecated注解
如果代碼使用了@Deprecated注解的類,方法或屬性,編譯器會進行警告。

@Deprecated使用很簡單,如下為注解一個棄用的類。

@Deprecatedpublic class MyComponent {}

當我們使用@Deprecated注解后,建議配合使用對應的@deprecated JavaDoc符號,并解釋說明為什么這個類,方法或屬性被棄用,已經替代方案是什么。

@Deprecated/** @deprecated This class is full of bugs. Use MyNewComponent instead.*/public class MyComponent {}

@Override

@Override注解用來修飾對父類進行重寫的方法。如果一個并非重寫父類的方法使用這個注解,編譯器將提示錯誤。

實際上在子類中重寫父類或接口的方法,@Overide并不是必須的。但是還是建議使用這個注解,在某些情況下,假設你修改了父類的方法的名字,那么之前重寫的子類方法將不再屬于重寫,如果沒有@Overide,你將不會察覺到這個子類的方法。有了這個注解修飾,編譯器則會提示你這些信息。

使用Override注解的例子

public class MySuperClass {  public void doTheThing() {    System.out.println("Do the thing");  }}public class MySubClass extends MySuperClass{  @Override  public void doTheThing() {    System.out.println("Do it differently");  }}

@SuppressWarnings

@SuppressWarnings用來抑制編譯器生成警告信息。

可以修飾的元素為類,方法,方法參數,屬性,局部變量

使用場景:當我們一個方法調用了棄用的方法或者進行不安全的類型轉換,編譯器會生成警告。我們可以為這個方法增加

@SuppressWarnings注解,來抑制編譯器生成警告。

注意:使用@SuppressWarnings注解,采用就近原則,比如一個方法出現警告,我們盡量使用@SuppressWarnings注解這個方法,而不是注解方法所在的類。雖然兩個都能抑制編譯器生成警告,但是范圍越小越好,因為范圍大了,不利于我們發現該類下其他方法的警告信息。

使用示例

@SuppressWarningspublic void methodWithWarning() {}

創建自己的注解

在Java中,我們可以創建自己的注解,注解和類,接口文件一樣定義在自己的文件里面。如下

@interface MyAnnotation {  String  value();  String  name();  int   age();  String[] newNames();}

上述代碼定義了一個叫做MyAnnotation的注解,它有4個元素。再次強調一下,@interface這個關鍵字用來告訴java編譯器這是一個注解。

仔細一看,你會發現,注解元素的定義很類似于接口的方法。這些元素有類型和名稱。這些類型可以是

  1. 原始數據類型
  2. String
  3. Class
  4. annotation
  5. 枚舉
  6. 一維數組

如下為應用自定義的注解

@MyAnnotation(  value="123",  name="Jakob",  age=37,  newNames={"Jenkov", "Peterson"})public class MyClass {}

注意,我們需要為所有的注解元素設置值,一個都不能少。

注解元素默認值

對于注解中的元素,我們可以為其設置默認值,使用方法為

@interface MyAnnotation {  String  value() default "";  String  name();  int   age();  String[] newNames();}

上述代碼,我們設置了value元素的默認值為空字符串。當我們在使用時,可以不設置value的值,即讓value使用空字符串默認值。 使用示例代碼

@MyAnnotation(  name="Jakob",  age=37,  newNames={"Jenkov", "Peterson"})public class MyClass {}

@Retention

@Retention是用來修飾注解的注解,使用這個注解,我們可以做到

控制注解是否寫入class文件
控制class文件中的注解是否在運行時可見

控制很簡單,使用使用以下三種策略之一即可。

RetentionPolicy.SOURCE 表明注解僅存在源碼之中,不存在.class文件,更不能運行時可見。常見的注解為@Override, @SuppressWarnings。
RetentionPolicy.CLASS 這是默認的注解保留策略。這種策略下,注解將存在與.class文件,但是不能被運行時訪問。通常這種注解策略用來處于一些字節碼級別的操作。
RetentionPolicy.RUNTIME 這種策略下可以被運行時訪問到。通常情況下,我們都會結合反射來做一些事情。

@Retention的使用示例

import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;@Retention(RetentionPolicy.RUNTIME)@interface MyAnnotation {  String  value() default "";}

@Target

使用@Target注解,我們可以設定自定義注解可以修飾哪些java元素。簡單示例

import java.lang.annotation.ElementType;import java.lang.annotation.Target;@Target({ElementType.METHOD})public @interface MyAnnotation {  String  value();}

上述的代碼說明MyAnnotation注解只能修飾方法。

@Target可以選擇的參數值有如下這些

  1. ElementType.ANNOTATION_TYPE(注:修飾注解)
  2. ElementType.CONSTRUCTOR
  3. ElementType.FIELD
  4. ElementType.LOCAL_VARIABLE
  5. ElementType.METHOD
  6. ElementType.PACKAGE
  7. ElementType.PARAMETER
  8. ElementType.TYPE(注:任何類型,即上面的的類型都可以修飾)

@Inherited

如果你想讓一個類和它的子類都包含某個注解,就可以使用@Inherited來修飾這個注解。

java.lang.annotation.Inherited@Inheritedpublic @interface MyAnnotation {}12@MyAnnotationpublic class MySuperClass { ... }1public class MySubClass extends MySuperClass { ... }

上述代碼的大致意思是

1.使用@Inherited修飾注解MyAnnotation
2.使用MyAnnotation注解MySuperClass
3.實現一個類MySubclass繼承自MySuperClass

通過以上幾步,MySubClass也擁有了MyAnnotation注解。

關于Java中的注解,一些基本的概念就是這些。

以上 就是關于Java 中的注解資料整理,后續繼續補充相關資料,謝謝大家對本站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 清苑县| 离岛区| 舟曲县| 紫云| 日土县| 宣汉县| 嘉义市| 万宁市| 汉阴县| 子长县| 湄潭县| 中江县| 阿鲁科尔沁旗| 连平县| 利津县| 布尔津县| 三台县| 青河县| 公安县| 湘潭市| 合江县| 平塘县| 秦安县| 乌鲁木齐县| 宜昌市| 六安市| 江安县| 霍邱县| 阿坝县| 沂源县| 新龙县| 阜新市| 尼玛县| 吴江市| 镇坪县| 永城市| 黔西| 北流市| 炎陵县| 沅江市| 大冶市|