Java注解

注解(也叫元數(shù)據(jù)),在代碼中添加信息提空一種形式化的方式,以便在稍后某個(gè)時(shí)刻非常方便地使用這些數(shù)據(jù)

內(nèi)置注解:

           java.lang中的注解:

                     @Dverride:表示覆蓋父類中的方法;

                     @Deprecated:如果程序使用了注解為它的元素,那么編譯器會(huì)發(fā)出警告信息;

                     @SupperessWarnings:關(guān)閉不當(dāng)?shù)木幾g器警告信息;

元注解:

         @Target:表示該注解可以用于什么地方。

                  可能的ElementType參數(shù)包括:

                  CONSTRUCTOR:構(gòu)造器的申明

                  FIELD:域生命(包括enum實(shí)例)

                  LOCAL_VARLABLE:局部變量聲明 

                  METHOD:方法聲明

                  PACKAGE:包聲明

                  PARAMETER:參數(shù)聲明

                  TYPE:類、接口(包括注解類型)或 enum聲明

         @Retention:表示需要在什么級(jí)別保存該注解信息。

                  可選的RetentionPolicy參數(shù)包括:

                  SOURCE:注解將被變異器丟棄

                  CLASS:注解在class文家中可用,但會(huì)被vm丟棄

                  RUNTIME:VM將在運(yùn)行期也保留注解,因此可以通過反射機(jī)制讀取注解信息

           @Documented:此注解包含在javadoc中

           @inherited:允許子類繼承父類中的注解        

注解元素:

            所有基本類型(int,float,boolean等)

                   String

                   Class

                   enum

                   Annotation

           以上類型的數(shù)組 

     注:不允許使用任何包裝類型,使用自動(dòng)打包可突破限制。注解可以嵌套注解

創(chuàng)建注解:

            import java.lang.annotation.ElementType;
            import java.lang.annotation.Retention;
            import java.lang.annotation.RetentionPolicy;
            import java.lang.annotation.Target;

            @Target(ElementType.METHOD)
            @Retention(RetentionPolicy.RUNTIME)
             public @interface UseCase {
                  public int id();

                  public String description() default "no description";
              }

使用注解:

            public class PasswordUtils {
                @UseCase(id = 47, description = "Passwords must conttain at least one numeric")
                public boolean validatePassword(String password) {
                    return (password.matches("\\w*\\d\\w*"));
                }

                @UseCase(id = 48)
                public String eccryptPassword(String password) {
                    return new StringBuilder(password).reverse().toString();// 取反
                }

                @UseCase(id = 49, description = "New password can't equal previously used ones")
                public boolean checkForNewPassword(List<String> prevPasswords, String password) {
                    return !prevPasswords.contains(password);// 包含
                }
            }

編寫注解處理器:

——Java編程思想讀書筆記

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容