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

首頁 > 編程 > Java > 正文

Java中三種簡單注解介紹和代碼實例

2019-11-26 15:25:36
字體:
來源:轉載
供稿:網友

簡單Java注解

JDK5提供的簡單注解類型只有3個. 這三個都是用來預防錯誤或者進行提醒的,分別是:

1.Override
2.Deprecated
3.Suppresswarnings

需要注意,JDK5(另一個說法,Tiger)實際上并沒有許多內置注解;相反,它允許核心Java支持注解特性的能力. JSR-175中嚴格規定它用來定義元數據功能. 需要由程序員編寫自定義的注解類型,其他JSR標準也編寫了一系列標準注解類型. 下面將用實例來深入講解這三個簡單注解.

Override 注解

Override 注解指明被注解的方法需要覆寫超類中的方法.

如果某個方法使用了該注解,卻沒有覆寫超類中的方法(比如大小寫寫錯了,或者參數錯了,或者是子類自己定義的方法),編譯器就會生成一個錯誤.

(注意: JRE5中實現接口中的方法時不能使用Override注解,JRE6允許了,很多時候JRE5會報這個錯).

示例1演示了覆寫注解:

Java注解示例1:

復制代碼 代碼如下:

public class Test_Override {
 @Override
 public String toString() {
    return super.toString() + "測試使用 'Override' 注解";
 }
}

如果出現方法名字拼寫錯誤會發生什么? 例如,如果你將toString方法改名為"tostring"(全小寫),編譯時就會得到類似下面這樣的出錯信息:

復制代碼 代碼如下:

Compiling 1 source file to D:tempNew Folder (2)
                              TestJavaApplication1buildclasses
D:tempNew Folder (2)TestJavaApplication1srctest
   myannotationTest_Override.java:24: method does not override
                a method from its superclass
@Override
1 error
BUILD FAILED (total time: 0 seconds)

當然,Eclipse就會直接報紅叉.現在IDE發展的很好用,初學者不應該去折騰JDK的命令行了.

Deprecated 注解

這個注解表明如果程序調用一個廢棄的(Deprecated,廢棄的,過時的)元素時,編譯器應該顯示警告信息. 示例2顯示了如何使用Deprecated 注解.

Java注解示例2

首先,創建一個類,并像下面這樣將某個方法標明為 廢棄:

復制代碼 代碼如下:

public class Test_Deprecated {
   @Deprecated
   public void doSomething() {
      System.out.println("測試使用 棄用 注解: 'Deprecated'");
   }
}

接著,嘗試從另一個類調用這個方法:

復制代碼 代碼如下:

public class TestAnnotations {
   public static void main(String arg[]) throws Exception {
      new TestAnnotations();
   }
   public TestAnnotations() {
   Test_Deprecated t2=new Test_Deprecated();
   t2.doSomething();
}

本例中的doSomething()方法被聲明為廢棄的方法. 因此,一般情況下不應該調用這個方法. 在編譯Test_Deprecated.java 文件時是不會有警告消息的. 但在編譯 TestAnnotations.java 時編譯器就會給出類似這樣的警告信息(Eclipse 會有警告):

復制代碼 代碼如下:

Compiling 1 source file to D:tempNew Folder
(2)TestJavaApplication1buildclasses
D:tempNew Folder
(2)TestJavaApplication1srctestmyannotation
    TestAnnotations.java:27:
warning: [deprecation] doSomething() in
test.myannotation.Test_Deprecated has been deprecated
t2.doSomething();
1 warning

Suppresswarnings 注解

這個注解告訴編譯器應該屏蔽帶注解的元素和所有子元素的警告信息. 會壓制一個元素集和子元素的所有警告信息. 比如,假設你在一個class上使用了Suppresswarnings 注解壓住一個警告,在它的一個方法上用Suppresswarnings 注解來壓制另一個警告,則兩種警告都會在方法級別被壓制住. 請參見示例3.

Java注解示例3:

復制代碼 代碼如下:

public class TestAnnotations {
   public static void main(String arg[]) throws Exception {
      new TestAnnotations().doSomeTestNow();
   }
   @SuppressWarnings({"deprecation"})
   public void doSomeTestNow() {
      Test_Deprecated t2 = new Test_Deprecated();
      t2.doSomething();
   }
}

在本例中,使用 @SuppressWarnings壓住了示例2中所示的deprecation警告信息. 因為該方法的這類警告被壓住了,所以你不會再看到"deprecation"警告.

注意: 在最內層的元素上使用該注解是比較好的. 因此,如果你只想在一個特定的方法上壓制一個警告,你應該在方法上標注,而不是在類上使用注解.

元注解(Meta-Annotations,Java注解類型)

元注解,實際上被稱為注解的注解,包含四種類型. 分別是:

1.Target
2.Retention
3.Documented
4.Inherited

Target 注解

Target注解表明注解類型適用于哪種目標元素. 它包含下面的枚舉類型值:

1.@Target(ElementType.TYPE)  ―― 可以適用于任何類的元素
2.@Target(ElementType.FIELD)  ―― 只適用于字段或屬性
3.@Target(ElementType.METHOD)  ―― 只適用于方法的注解
4.@Target(ElementType.PARAMETER)  ―― 只適用于方法的參數
5.@Target(ElementType.CONSTRUCTOR) ―― 只適用于構造函數
6.@Target(ElementType.LOCAL_VARIABLE) ―― 只適用于局部變量
7.@Target(ElementType.ANNOTATION_TYPE) ―― 指明聲明類型本身是一個注解類型

示例4演示了Target 注解:

Java注解示例4

首先,定義了一個名為Test_Target的注解類型,帶上 @Target元注解,如下所示:

復制代碼 代碼如下:

@Target(ElementType.METHOD)
public @interface Test_Target {
   public String doTestTarget();
}

接下來,創建一個類,它將使用Test_Target注解:

復制代碼 代碼如下:

public class TestAnnotations {
   public static void main(String arg[]) {
      new TestAnnotations().doTestTarget();
   }
   // 在方法上使用注解,OK.
   // 中間也可以不換行,換2行之類,Java忽略多余的換行
   @Test_Target(doTestTarget="Hello World !")
   public void doTestTarget() {
      System.out.printf("Testing Target annotation");
   }
}

@Target(ElementType.METHOD) 注解表明該注解類型只能被用來注解方法. 如果你編譯這段代碼,不會顯示警告消息. 但是,如果將這個注解聲明到一個字符串變量上,會發生什么呢? 就像下面這樣:

復制代碼 代碼如下:

public class TestAnnotations {
   // 這是錯誤的做法,編譯不會通過,因為注解的Level不對.
   // 元注解指明了只能注解方法,就不能用來注解屬性
   @Test_Target(doTestTarget="Hello World !")
   private String str;
   public static void main(String arg[]) {
      new TestAnnotations().doTestTarget();
   }
   public void doTestTarget() {
      System.out.printf("Testing Target annotation");
   }
}

唯一的變化就是注解聲明從方法級轉向字段級,這是不正確的. 因為你已經定義了注解   @Test_Target 只適用在方法級,如果你嘗試編譯這個類,你可能會得到這樣的錯誤信息:

復制代碼 代碼如下:

"TestAnnotations.java":
D:R_AND_DTestAnnotationsrctestmyannotation
   TestAnnotations.java:16:
annotation type not applicable to this kind of declaration at line
16, column 0
@Test_Target(doTestTarget="Hello World !")
^
Error in javac compilation

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 德兴市| 北安市| 临朐县| 通化县| 陕西省| 新津县| 德兴市| 南雄市| 卢氏县| 长垣县| 西乡县| 页游| 道孚县| 图木舒克市| 枝江市| 洛隆县| 绿春县| 资兴市| 沈阳市| 淮北市| 马公市| 万宁市| 广昌县| 个旧市| 吉隆县| 乌什县| 平潭县| 眉山市| 蒙自县| 武宣县| 印江| 兰坪| 渝北区| 泰安市| 湘乡市| 专栏| 驻马店市| 时尚| 韩城市| 集贤县| 团风县|