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

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

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

    Open Java Project

    Keep it simple, Stupid, Less is more

    BlogJava 首頁 新隨筆 聯系 聚合 管理
      20 Posts :: 0 Stories :: 12 Comments :: 0 Trackbacks

    1、引入

    l         編程的一個最新趨勢,尤其是 Java 編程,就是使用元數據

    l         元數據可以用于創建文檔,跟蹤代碼中的依賴性,甚至執行基本編譯時檢查

    l         許多元數據工具(如 Xdoclet)將這些功能添加到核心 Java 語言中,暫時成為 Java 編程功能的一部分

    l         Javadoc是元數據工具,但除了生成文檔之外,沒有固定、實用、標準化的方式將數據用于其他用途,而且HTML代碼經常混入到Javadoc輸出中,更進一步降低了其用于任何其它目的的價值

    l         JSR 175Java編程語言的元數據工具,為將元數據合并到核心 Java 語言中提供了正式理由和說明

    l         Tiger 增加了Annotation的新功能,將一個更通用的元數據工具合并到核心 Java 語言中

    l         Annotation是可以添加到代碼中的修飾符,可以用于包聲明、類型聲明、構造函數、方法、域變量、參數和變量

    l         Tiger包含內置的Annotation,還支持自己編寫的定制Annotation

    l         本部分將概述元數據的優點,并介紹Tiger的內置Annotation

     

    2、元數據的價值

    一般來說,元數據的好處分為三類:文檔編制、編譯器檢查和代碼分析

    1)文檔編制

    l         代碼級文檔最常被引用,但對于將元數據添加到 Java 語言中來說,文檔編制可能是最不相關的理由

    l         因為Javadoc已經提供了非常容易理解和健壯的方法來文檔化代碼

    2)編譯時檢查

    l         元數據更重要的優點是編譯器可以使用它來執行基本的編譯時檢查

    l         具體情況請參看后面介紹的Tiger內置Annotation@Override

    3)代碼分析

    l         元數據工具的最好功能就是可以使用額外數據來分析代碼

    l         簡單的案例就是:許多時候,方法的參數類型或返回類型實際上不是該方法想要的類型;例如,參數類型可能是Object,但方法可能僅使用Integer,這在覆蓋超類的方法時很容易發生;元數據可以指示代碼分析工具:雖然參數類型是 Object,但 Integer 才是真正需要的

    l         復雜的案例就是:即使是簡單EJB系統中也具有很強的依賴性和復雜性,要具有 HomeRemote接口,以及本地的Home Remote接口,以及一個實現類,保持所有這些類同步非常困難;好的工具(如XDoclet)可以管理所有這些依賴性,并確保這些沒有“代碼級”聯系,但有“邏輯級”聯系的類保持同步;元數據在這里確實可以發揮它的作用

     

    3Annotation基礎

    l         Annotation的格式是:@Annotation

    l         Annotation需要數據時,通過name=value的形式提供

    l         代碼中可以用很多Annotation,有些Annotation會具有相同的Annotation類型

    l         Annotation類型和Annotation的概念類似于類和對象的概念

    l         Annotation有三種基本種類:

    ?         標記Annotation:只有Annotation名,不包含數據,如@MarkerAnnotation

    ?         單值Annotation:只有單一的數據,可以簡化name=value的形式為value形式,如@SingleValueAnnotation("my data")

    ?         完整格式的Annotation:有多個數據成員,如@FullAnnotation(var1="data value 1", var2="data value 2", var3="data value 3")

    l         可以使用花括號向Annotation變量提供值數組,如

    @TODOItems({    // Curly braces indicate an array of values is being supplied
      @TODO(
        severity=TODO.CRITICAL,
        item="Add functionality to calculate the mean of the student's grades",
        assignedTo="Brett McLaughlin"
      ),
      @TODO(
        severity=TODO.IMPOTANT,
        item="Print usage message to screen if no command-line flags specified",
        assignedTo="Brett McLaughlin"
      ),
      @TODO(
        severity=TODO.LOW,
        item="Roll a new website page with this class's new features",
        assignedTo="Jason Hunter"
      )
    })

     

    4Tiger內置Annotation

    1@Override

    l         @Override只用于方法,指明改方法覆蓋超類中的對應方法

    l         簡單例子:

    public class OverrideTester {
     
           public OverrideTester() {
           }
     
           @Override public String toString() {
                  return super.toString() + " [Override Tester Implementation]";
           }
     
           @Override public int hashCode() {
                  return toString().hashCode();
           }
    }

    l         @Override可以檢查輸入錯誤導致無法覆蓋超類方法的問題,例如hashCode()錯誤的輸入為hasCode(),在編譯時就會報錯:

    The method hasCode() of type OverrideTester must override a superclass method

    l         這個便捷的小功能將幫助快速捕獲打字錯誤

    2@Deprecated

    l         同樣只用于方法,指明該方法不應該再使用了

    l         簡單例子:

    public class DeprecatedClass {
     
           @Deprecated public void doSomething() {
                  System.out.println("Deprecated method!");
                  // some code
           }
     
           public void doSomethingElse() {
                  // This method presumably does what doSomething() does, but better
           }
    }

    l         單獨編譯正常通過,如果通過覆蓋或調用Deprecated方法,編譯器會給出警告信息

    l         注:本人在Eclipse 3.1M4環境中測試,根本不起作用(即使是改了編譯參數,why?),在命令行下使用-Xlint:deprecated參數,JAVAC只給出警告信息,編譯還是通過的

    3@SuppressWarnings

    l         Tiger的泛型功能使得編譯器對類型的安全性進行檢查,特別是Java集合,如下面的例子:

           public void nonGenericsMethod() {
                  List wordList = new ArrayList(); // no typing information on the List
                  wordList.add("foo"); // causes error on list addition
           }

    l         編譯器會給出下面的警告信息:

    Type safety: The method add(Object) belongs to the raw type List. References to generic 
     type List<E> should be parameterized

    l         這對于Tiger的代碼是很有幫助的,但對于JDK1.4及以前版本,不斷的收到無關的警告信息是很煩人的

    l         可以使用@SuppressWarnings來阻止指定類型的警告信息,如:

           @SuppressWarnings(value = { "unchecked" }) 
           public void nonGenericsMethod() {
                  List wordList = new ArrayList(); // no typing information on the List
                  wordList.add("foo"); // causes error on list addition
           }

    l         傳遞給@SuppressWarnings的類型值是一個數組,因此可以同時阻止多種類型的警告信息

    l         類型值是由編譯器廠商所指定的,所以上面的例子我在Eclipse 3.1M4環境和命令行中測試,都不起作用,大概是類型值沒有指定對吧

    posted on 2005-03-21 22:01 nelson_tu 閱讀(2349) 評論(1)  編輯  收藏 所屬分類: Tiger系列

    Feedback

    # 3.1M4根本未完全支持JDK5的特性 2005-04-03 18:20 PopEast
    用3.1M5a以上吧  回復  更多評論
      

    主站蜘蛛池模板: 男女一边摸一边做爽的免费视频| 久久亚洲中文无码咪咪爱| 久久WWW免费人成—看片| 国产成人在线观看免费网站| 亚洲综合精品成人| 最新免费jlzzjlzz在线播放| 亚洲中文字幕乱码AV波多JI| 精品久久洲久久久久护士免费| 亚洲人av高清无码| 免费a级黄色毛片| 国产免费人成视频在线播放播| 伊伊人成亚洲综合人网7777| 99在线免费视频| 亚洲视频在线观看视频| 4399好看日本在线电影免费| 国产亚洲国产bv网站在线| 成全视频在线观看免费高清动漫视频下载 | 日韩一级片免费观看| 亚洲色偷偷综合亚洲AV伊人| 99免费精品视频| 亚洲国产成人无码av在线播放| 日本免费一区二区三区最新vr| 免费人成网上在线观看| 国产AV无码专区亚洲Av| 午夜免费1000部| 黄页网站在线观看免费| 亚洲午夜福利AV一区二区无码| 免费精品无码AV片在线观看| 国产成人亚洲综合一区| 亚洲成人一区二区| 日本在线看片免费人成视频1000| 亚洲中文无码mv| 亚洲第一AV网站| 黄网址在线永久免费观看 | 亚洲日本成本人观看| 中文字幕亚洲综合久久男男| 69影院毛片免费观看视频在线| 免费播放美女一级毛片| 国产AV无码专区亚洲A∨毛片| 毛片a级毛片免费播放100| 国产日韩久久免费影院|