<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    幻境
    We are extremely fortunate not to know precisely the kind of world we live in
    posts - 22,comments - 39,trackbacks - 0

    J2SE 5.0通過引入注釋(Annotation)的概念添加了對元數據的支持。

    一個@xxx形式的注釋可以當成一個修飾符來使用,它可以放在任何一個修飾符可以出現的地方。public,static,final都是java語言的修飾符,注釋可以寫在它們可以出現的任何地方。

    舉個例子,可以看下面一段代碼:

    public class AnnotationExample {

        public @Override int hashCode() {

           return super.hashCode();

        }

    }

     

    在這個例子中我們使用了一個java語言API中已經有定義的注釋@Override,通過在方法hashCode()中使用這個注釋,說明了hashCode是一個覆蓋了父類方法的方法。

    至于注釋的具體含義我們在以后部分會說明。

    如果你想使用一個類,你必須首先找到它的定義,或者你自己對它進行定義。注釋也是需要定義的,隨便在代碼中插入一個@XXX之類的注釋是不能夠通過編譯的。

    一個最簡單的Annotation定義類似于接口的定義,就象下面的代碼:

    public @interface Info {

    }

     

    正如你所看到的,里面什么都沒有,但是即使是這樣,我們也可以在程序里使用它:

    public @Info String  information;

     

    這樣的一種什么都沒有定義的空注釋我們稱為標記注釋(marker annotations

    我們可以在其中添加一個成員的定義:

    public @interface Info {   

         String author();

    }

     

    這里值得注意的一點是,注釋類中方法的定義不能是私有的,如果你不在前面加public關鍵字,編譯器會默認為它是公有的。

    在添加上author的定義后,原來那種只寫了一個@Info的注釋就必須修改了,之后的注釋必須這樣寫:

    public @Info(author="myname")  void afunction() {

    }

     

    一個注釋的成員可以有默認值:

    public @interface Info {   

         String author() default "myname";

    }

     

    使用默認值有什么好處呢?我們可以重新這樣寫了:

    public @Info  void afunction() {

    }

     

    在做標記時,如果確認某個成員的值和它的默認值相同,我們就可以忽略它,而不必顯式地給每個成員賦值,這樣就減輕了代碼量。

    如果我們添加的這個成員名字叫做value的話,也就是:

    public @interface Info {   

         String value();

    }

     

    就有了另外一種注釋的用法: 我們可以直接寫出這樣的注釋@Info(“information”),而不必寫@Info(value=”information”),括號里的值會自動傳遞給value。這樣的一種注釋稱為單一值注釋(Single-value annotations

    一個注釋可以有很多類型不同的成員,這樣的一種注釋稱為完整注釋(full annotations

    一個注釋中的成員類型只能夠是原生類型,字符串,Class類型,注釋類型,枚舉類型,或者一維數組。

    假設我們現在有一個注釋定義:

    public @interface Company {

        String value();

    }

     

    現在我們希望定義另外一個注釋,這個注釋類型反映了一個人的信息:

    public @interface Person {

        public enum Gender{MALE,FEMALE};

       

        String name();

        int age();

        Company company();

        Gender gender() default Gender.MALE;

        String description() default "";

    }

     

    在程序代碼中添加這種類型的注釋時可以這么寫:

    @Person(age=23,name="MyName",gender=Person.Gender.FEMALE, company=@Company("Foo Corporation"))

     

    java.lang包中定義了三種注釋,分別是:

    n         Deprecated:和過去javadoc@deprecated含義相同

    n         Override:表示方法覆蓋了父類中的方法

    n         SuppressWarnings:使用這個注釋可以使編譯器忽略特定類型的警告信息

    具體含義可以參照api文檔。

    我們知道,注釋的引入,為java語言添加了元數據的表達方式,而元數據就是關于數據的數據。在java中,還有關于注釋的注釋,我們相應的稱之為元注釋(meta-annotations

    java中,我們可以使用4種預先定義的注釋對注釋定義進行注釋,這4種注釋是:

    n         Target:指明注釋可以在哪些代碼段中使用,以避免對注釋的誤用。

    n         Retention:說明編譯器在編譯和運行時是否忽略該種注釋

    n         Documented:說明注釋是否出現在Javadoc

    n         Inherited:當我們在一個類中使用了某種注釋,有時候會希望將來它的所有子類中都包含有該種注釋信息,如果在注釋定義中添加了@Inherited,那么這種注釋就會被調用者的子類繼承

    當我們在一個類中使用注釋定義了一系列的元數據之后,我們應該如何獲取這些元數據呢?我們通過下面的例子來說明。

    Annotation的定義仍然使用列出來的兩個,因為我們需要在獲得類文件中的注釋信息,所以必須在注釋定義中添加Retention注釋。

    首先我們定義兩個注釋,注釋Todo說明了還有什么事情需要做:

    import java.lang.annotation.Retention;

    import java.lang.annotation.RetentionPolicy;

     

    @Retention(RetentionPolicy.RUNTIME)

    public @interface Todo {

        String value();

    }

     

    注釋Author說明了一個方法或者類的定義者:

    import java.lang.annotation.Retention;

    import java.lang.annotation.RetentionPolicy;

     

    @Retention(RetentionPolicy.RUNTIME)

    public @interface Author {

        public enum Gender{MALE,FEMALE};

     

        String name();

        String email();

        Gender gender() default Gender.MALE;

    }

     

    然后我們在一個簡單的類中添加這兩種類型的注釋:

    public @Todo("delete this class") class Foo {

       

        public void methodA(){}

        public @Author(name="B",email="b@Foo.com") void methodB(){

        }

       

        public @Author(name="A",email="a@Foo.com") String  fieldA;

    }

     

    通過下面一段代碼我們可以提取相應的元數據:

    import java.lang.reflect.Method;

     

    public class GetAnnotations {

     

        public static void main(String[] args) {

           try {

               Class<?> klass=Class.forName(args[0]);

               if(klass.isAnnotationPresent(Todo.class))

               {

                  Todo t=klass.getAnnotation(Todo.class);

                  System.out.println(t);

               }

               for(Method m:klass.getMethods())

               {

                  if(m.isAnnotationPresent(Author.class))

                  {

                      Author a=m.getAnnotation(Author.class);

                      System.out.printf("Method:%s,Author:%s%n",m.getName(),a);

                  }

               }

           } catch (ClassNotFoundException e) {

              

               e.printStackTrace();

           }

        }

    }

     

     

    使用下面的命令行運行程序:

    java GetAnnotations Foo

     

    運行結果如下:

    @Todo(value=delete this class)

    Method:methodB,Author:@Author(gender=MALE, name=B, email=b@Foo.com)

     

    posted on 2005-05-12 10:56 閱讀(994) 評論(0)  編輯  收藏 所屬分類: 編程相關
    主站蜘蛛池模板: 国产亚洲高清在线精品不卡| 国产成人免费手机在线观看视频| 免费人成再在线观看网站 | 老外毛片免费视频播放| 亚洲视频免费观看| 亚洲日韩欧洲乱码AV夜夜摸| 国产男女猛烈无遮挡免费网站| 免费H网站在线观看的| 久久久久国产精品免费看| 精品97国产免费人成视频| 免费看一级一级人妻片| 免费亚洲视频在线观看| 亚洲午夜无码久久久久软件| 亚洲欧洲日产国码www| 亚洲成在人线av| 国产亚洲一区区二区在线| 无码不卡亚洲成?人片| 国产猛烈高潮尖叫视频免费 | 亚洲一区无码中文字幕乱码| 亚洲视频.com| 久久青青草原亚洲AV无码麻豆| 亚洲一本大道无码av天堂| 国产三级免费观看| 国产精品无码一二区免费| 免费鲁丝片一级观看| 成人人免费夜夜视频观看| 无码日韩人妻av一区免费| 久久精品无码一区二区三区免费 | 亚洲第一页在线视频| 亚洲精品私拍国产福利在线| 久久精品国产亚洲av麻| 亚洲午夜精品一区二区| 亚洲天堂久久精品| 亚洲人成黄网在线观看| 国产.亚洲.欧洲在线| 亚洲色大成网站WWW国产| 亚洲av成人中文无码专区| 免费视频成人国产精品网站| 人妻巨大乳hd免费看| 黄页免费在线观看| 91久久青青草原线免费|