哈嘍,大家好,這是我的第一篇文章,我希望能夠將所學習的知識進行歸納總結,並且與大家進行分享,接下來的一段時間會發佈一系列Java、Python等入門等級相關文章,並且是有系統的進行分享,夯實基礎才能走的更遠。希望大家不吝賜教!廢話不多說,上乾貨! (如有涉及侵權處,請透過此平台聯絡本人刪除)
XML作為設定檔受到了大部分程式設計師的喜愛,但也有人會偏愛使用註解,其實個人覺得選擇什麼並不是重點,重點是要了解每一個技術誕生的本質;XML作為配置文件和代碼是“松耦合”的代碼描述,但是當XML配置檔案過多時難以管理,同時IDE無法對XML設定檔的正確性進行校驗,增加測試難度;而註解則是「緊密耦合」的程式碼描述,它的目的是為了讓應用程式更易於擴展的同時做到“零”配置。
一、什麼是註解(Annotation)
註解即標註,是程式碼中的元資料(元資料:描述資料的資料),透過使用註解使得程式開發人員可以在不改變原有邏輯的情況下,在原始檔案中嵌入一些補充資訊。請看以下程式碼片段:
對於初學者而言,其實常常會看到類似程式碼,心裡會想@Override是什麼鬼?其實它就是註解,在toString()方法上加入@Override,表示該註解下面的toString()方法必須重構父類別方法。
看到這裡我想有人就會認為接下來我會跟大家介紹各種各樣的註解了? !我偏不!
二、註解類型的語法標準
註解是Java中一種特殊的類型,接下來我們來看看如何設計一個註解類型。
1、文法標準:
public @interface 注解类型名称 { [ 数据类型 变量名 () [ default 初始值 ]; ] }
註:
1)"[ ]"中的內容可有可無,若註解為標識註解。
2)註解中智慧包含變量,不能包含方法。
3)註解是程式碼裡的特殊標記,不可以單獨使用,需要配合類別或介面一起使用。
4)註解類型可以用來為程式元素設定元資料(程式元素:類別、方法、成員變數等)。
2、案例:設計註解類型Testable,由此註解標識的方法為可測試方法。此註解內部為空,表示該註解為識別註解。
public @interface Testable { }
public class Test { @Testable public void info() { System.out.println(“我是info方法”); } public void info1() { System.out.println(“我是info1方法”); } }
該類別中加入@Testable註解,表示info方法為可執行到的方法,僅僅是描述該方法是可被執行的方法而已,並不會有任何動態交互能力,如果想要達成此註解的作用必須要編寫配套的Java應用程序,具體程式碼可參考以下程式碼。
大家可以思考,如果想要解析一個類別的內部結構,我們可以透過什麼技術來實現呢?
答案是:反射機制(接下來這段有關於反射機制的相關內容不清楚的朋友們,按照下面程式碼進行調試,具體反射機制的相關知識稍後會發布)。
在java.lang.reflect套件中常見的具有反射功能的工具類別:Method(方法類別)、Field(字段類別)、Constructor(建構方法類別)等。
以上這些工具類別擴充了讀取執行時間註解的能力,即實作java.lang.annotation.AnnotatedElement介面;此介面是所有程式元素的父接口,該介面中提供了用於取得註解資訊的相關方法。
getAnnotation(Class
Annotation [] getAnnotations():傳回該程式元素上存在的所有註解。
Annotation是所有註解的父接口,預設任何一個接口類型都會實作該接口。
boolean isAnnotationPresent(Class Extends Annotation> annotationClass):判斷程式元素上是否包含指定類型的註解,存在則傳回true,否則回傳false。
程式碼參考:
解析Test類,並執行帶有@Testable標識的方法。
import java.lang.reflect.Method; public class UseTest { public static void main(String[] args)throws Exception { Class c=Class.forName(“Test”); Object o=c.newInstance(); Method[] me=c.getDeclaredMethods(); for(Method temp:me) { if(temp.isAnnotationPresent(Testable.class)) temp.invoke(o,new Object[0]); } } }
好了,到現在為止大家可以執行程式看一下效果了!
。 。 。 。 。 。 。
是不是特別無語(ˉ▽ˉ;)...,透過執行程式碼會發現程式並無任何結果,和我們想想的不太一樣? !
欲知後事如何,請看下回分解!
三、總結:
接下來讓我們總結一下朋友們所需要掌握的知識點。
1、XML與註解的差異
2、什麼是註解
#3、註解設計的語法標準
4、反射機制
5、java.lang.annotation.AnnotationElement的方法及作用
四、結束語
和大家說我匆匆結束的原因,第一次寫文章,不知道發佈出去的內容格式是什麼樣的,剩餘相關知識請看下一篇文章,謝謝大家的支持。
以上是Java 註解——Java自己的設定文件的詳細內容。更多資訊請關注PHP中文網其他相關文章!