国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

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

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - Java中三種簡單注解介紹和代碼實例

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

2019-11-28 14:24renfufei JAVA教程

這篇文章主要介紹了Java中三種簡單注解介紹和代碼實例,本文講解了Override注解、Deprecated注解、Suppresswarnings注解、元注解等內容,需要的朋友可以參考下

簡單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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩精品极品视频在线观看免费 | 一 级 黄 色 片免费网站 | 中文字幕在线观看第一页 | 亚洲在线一区二区 | 综合精品 | 日韩免费在线视频 | 噜噜噜噜狠狠狠7777视频 | 国产91在线观看 | 亚洲视频在线观看网址 | 男人天堂亚洲 | 99精品欧美一区二区蜜桃免费 | www午夜| 亚洲欧美日韩精品 | 国产成年免费视频 | 人人人射| 一级片在线观看 | 美女在线视频一区二区 | 国产精品永久免费视频 | 精品www | 操操爱| 亚洲电影在线 | 国产精品一区欧美 | 91欧美激情一区二区三区成人 | 中国黄色毛片 大片 | 97成人在线免费视频 | 在线日韩 | 国产精品永久久久久久久久久 | 久久成人精品 | 亚洲 成人 av| 久久精品免费一区二区三区 | 四房婷婷 | 在线视频中文字幕 | 亚洲成av人片在线观看 | 黄色美女网站在线观看 | 久久一区二区三区四区 | 国产精品视频在线观看 | 欧美日韩激情一区 | 狠狠操电影 | 亚洲成人免费视频 | 国产一级毛片aaa | 在线观看免费视频国产 |