亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

ANT 十五大最佳實踐經典案例分析

2019-11-18 12:53:36
字體:
來源:轉載
供稿:網友

  在ANT出現之前,編譯和部署java應用需要使用包括特定平臺的腳本、Make文件、不同的IDE以及手工操作等組成的大雜燴。現在,幾乎所有的開源Java項目都在使用Ant,許多公司的開發項目也在使用Ant。Ant的大量使用,也自然帶來了對總結Ant最佳實踐的迫切需求。
  
  1. 采用一致的編碼規范
  Ant用戶不管是喜歡還是痛恨xml構建文件的語法,都愿意跳進這一迷人的爭論中。讓我們先看一些保持XML構建文件簡潔的方法。
  首先,也是最重要的,化費時間格式化你的XML讓它看上去很清楚。不過XML是否美觀,Ant都可以工作。但是丑陋的XML很難讀懂。倘若你在任務之間留出空行,有規則的縮進,每行文字不超過90列,那么XML令人驚奇的易讀。再加上好的編輯器或IDE高亮相應的語句,你就不會有如何閱讀的麻煩。
  同樣,精選有意義明確、輕易讀懂的詞匯來命名任務和屬性。比如,dir.reports就比rpts好。并不需要特定的編碼規范,只要有一種規范并堅持使用就好。
  
  2. 將build.xml 放在項目根目錄中
  Ant構建文件build.xml可以放在如何位置,但是放在項目頂層目錄中可以保持項目簡潔。這是最普遍的規范,使開發者能夠在根目錄找到它。同時,也能夠輕易了解項目中不同目錄之間的邏輯關系。以下是一個典型的項目層次:
  
  [root dir]
    build.xml
   +--src
   +--lib (包含第三方 JAR包)
   +--build (由 build任務生成)
   +--dist (由 build任務生成)
  當build.xml在頂級目錄時,倘若你在項目某個子目錄中,只要輸入:ant -find compile 命令,不需要改變工作目錄就能夠以命令行方式編譯代碼。參數-find告訴Ant尋找存在于上級目錄中的build.xml并執行。
  
  3. 使用單一構建文件
  有人喜歡將一個大項目分解到幾個小的構建文件,每個構建文件分擔整個構建過程的一小部分工作。但是應該熟悉到,將構建文件分割會增加對整個構建過程的理解難度。要注重在單一構建文件能夠清楚表現構建層次的情況下,不要過工程化(over-engineer)。
  即使你把項目劃分為多個構建文件,也應使程序員能夠在項目根目錄下找到核心build.xml。盡管該文件只是將實際構建工作委派給下級構建文件,也應保證該文件可用。
  
  4. 提供良好的幫助說明
  應盡量使構建文件自文檔化。增加任務描述是最簡單的方法。當你輸入ant -PRojecthelp時,你就可以看到帶有描述的任務清單。比如,你可以這樣定義任務:
  <target name="compile"
  description="Compiles code, output goes to the build dir.">
  最簡單的規則是對所有你希望程序員通過命令行直接調用的任務都加上描述。對于一般用來執行中間處理過程的內部任務,比如生成代碼或建立輸出目錄等,就無法使用描述屬性。
  這時,可以通過在構建文件中加入XML注釋來處理。或者專門定義一個help任務,當程序員輸入ant help時來顯示具體的使用說明。
  <target name="help"
      description="Display detailed usage information">
   <echo>Detailed help...</echo>
  </target>
  
  5. 提供清空任務
  每個構建文件都應包含一個清空任務,刪除所有生成的文件和目錄,使系統回到構建文件執行前的初始狀態。執行清空任務后還存在的文件應處在版本控制系統的治理下。
  比如:
  <target name="clean"
    description="Destroys all generated files and dirs.">
   <delete dir="${dir.build}"/>
   <delete dir="${dir.dist}"/>
  </target>
  除非是在產生整個系統版本的非凡任務中,否則不要自動調用clean任務。當程序員僅僅執行編譯任務或其他任務時,他們不需要構建文件事先執行即令人討厭有沒有必要的清空任務。要相信程序員能夠確定何時需要清空所有文件。
  
  6. 使用ANT治理任務從屬關系
  假設你的應用由Swing GUI組件、Web界面、EJB層和公共應用代碼組成。在大型系統中,你需要清楚地定義Java包屬于系統的哪一層。否則如何一點修改都要重新編譯成千上百個文件。任務從屬關系治理差會導致過度復雜而脆弱的系統。改變GUI面板的設計不應造成Servlet和EJB的重編譯。
  當系統變得龐大后,稍不注重就可能將依靠于客戶端的代碼引入到服務端。這是因為IDE在編譯文件時使用單一的classpath。Ant讓你更有效地控制構建活動。
  設計你的構建文件編譯大型項目的步驟:首先,編譯公共應用代碼,將編譯結果打成JAR包文件。然后,編譯上一層的項目代碼,編譯時依靠第一步產生的JAR文件。不斷重復這一過程,直到最高層的代碼編譯完成。
  分步構建強化了任務從屬關系治理。假如你工作在底層Java框架上,引用高層的GUI模板組件,這時代碼不需要編譯。這是由于構建文件在編譯底層框架時,在源路徑中沒有包含高層GUI面板組件的代碼。
  
  7. 定義并重用文件路徑
  假如文件路徑在一個地方集中定義,并在整個構建文件中得到重用,那么構建文件更易于理解。以下是這樣做的一個例子:
  <project name="sample" default="compile" basedir=".">
   <path id="classpath.common">
    <pathelement location="${jdom.jar.withpath}"/>
    ...etc
   </path>
   <path id="classpath.client">
    <pathelement location="${guistuff.jar.withpath}"/>
    <pathelement location="${another.jar.withpath}"/>
    <!-- reuse the common classpath -->
    <path refid="classpath.common"/>
   </path>
   <target name="compile.common" depends="prepare">
    <javac destdir="${dir.build}" srcdir="${dir.src}">
       <classpath refid="classpath.common"/>
       <include name="com/oreilly/common/**"/>
    </javac>
   </target>
  </project>
  當項目不斷增長,構建日益復雜時,這一技術越發體現出其價值。你可能為編譯不同層次的應用定義各自的文件路徑,比如運行單元測試的、運行應用程序的、運行Xdoclet的、生成JavaDocs的等等不同路徑。這種組件化路徑定義的方法比為每個任務單獨定義路徑要優越得多。否則,很輕易丟失任務任務從屬關系的軌跡。
  
  8. 定義恰當的任務參數關系
  假設dist任務從屬于jar任務,那么哪個任務從屬于compile任務,哪個任務從屬于prepare任務呢?Ant構建文件最終定義了任務的從屬關系圖,它必須被仔細地定義和維護。
  應該定期檢查任務的從屬關系以保證構建工作得到正確執行。大的構建文件隨著時間推移趨向于增加更多的任務,所以到最后由于不必要的從屬關系導致構建工作非常困難。比如,你可能發現在程序員只是需要編譯一些沒有使用EJB的GUI代碼時,重新生成EJB代碼。
  以“優化”的名義忽略任務的從屬關系是另一種常見的錯誤。這種錯誤迫使程序員為了得到恰當的結果必須記住并按照特定的順序調用一串任務。更好的做法是:提供描述清楚的公共任務,這些任務包含正確的任務從屬關系;另外提供一套“專家”任務讓你能夠手工執行個別的構建步驟,這些任務不提供完整的構建過程,但是讓那些專家在快速而惱人的編碼期間跳過某些步驟
  
  9.使用配置屬性
   任何需要配置或可能發生變化的信息都應作為Ant屬性定義下來。對于在構建文件中多次出現的值也同樣處理。屬性既可以在構建文件頭部定義,也可以為了更好的靈活性而在單獨的屬性文件中定義。以下是在構建文件中定義屬性的樣式:
  <project name="sample" default="compile" basedir=".">
   <property name="dir.build" value="build"/>
   <property name="dir.src" value="src"/>
   <property name="jdom.home" value="../java-tools/jdom-b8"/>
   <property name="jdom.jar" value="jdom.jar"/>
   <property name="jdom.jar.withpath"
            value="${jdom.home}/build/${jdom.jar}"/>
    etc...
  </project>
  或者你可以使用屬性文件:
  <project name="sample" default="compile" basedir=".">
   <property file="sample.properties"/>
    etc...
  </project>
  在屬性文件 sample.properties中:
  dir.build=build
  dir.src=src
  jdom.home=../java-tools/jdom-b8
  jdom.jar=jdom.jar
  jdom.jar.withpath=${jdom.home}/build/${jdom.jar}
  用一個獨立的文件定義屬性是有好處的,它可以清楚地定義構建中的可配置部分。另外,在開發者工作在不同操作系統的情況下,你可以在不同的平臺上提供該文件的不同版本。
  
  10. 保持構建過程獨立
  為了最大限度的擴展性,不要應用外部路徑和庫文件。最重要的是不要依靠于程序員的CLASSPATH設置。取而代之的是,在構建文件中使用相對路徑并定義自己的路徑。假如你引用了絕對路徑如C:/java/tools,其他開發者未必使用與你相同的目錄結構,所以就無法使用你的構建文件
  假如你部署開發源碼項目,應該提供包括所有需要的JAR文件的發行版本,當然是在遵守許可協議的基礎上。對于內部項目,相關的JAR文件都應在版本控制系統的治理中,并撿出到大家都知道的位置。
  當你不得不應用外部路徑時,應將路徑定義為屬性。使程序員能夠涌適合他們自己的機器的參數重載這些屬性。你也可以使用以下語法引用環

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91网在线免费观看| 国产97在线|日韩| 国模gogo一区二区大胆私拍| 成人欧美一区二区三区在线湿哒哒| 91精品免费视频| 国产啪精品视频网站| 综合网中文字幕| 精品久久久久久久久久久久| 亚洲小视频在线观看| 日韩免费黄色av| 欧美裸体xxxx| 国产精品久久久久久久久久久久久久| 亚洲欧美精品伊人久久| 久久久久久久久国产精品| 国产有码一区二区| 亚洲一区中文字幕| 最近中文字幕2019免费| 91亚洲精品一区| 亚洲精品国产精品久久清纯直播| 亚洲美女在线视频| 国产精品96久久久久久又黄又硬| 久久69精品久久久久久国产越南| 日韩专区在线播放| 国产偷亚洲偷欧美偷精品| 日韩视频一区在线| 欧美黑人狂野猛交老妇| 插插插亚洲综合网| 亚洲免费视频在线观看| 日韩欧美亚洲国产一区| 国产美女被下药99| 日韩精品极品在线观看播放免费视频| 色婷婷av一区二区三区久久| 欧美一级高清免费| 中文字幕日韩精品在线观看| 色婷婷综合久久久久中文字幕1| 色综合视频一区中文字幕| 国产美女高潮久久白浆| 国产精品a久久久久久| 中文字幕日韩欧美精品在线观看| 亚洲第一精品夜夜躁人人躁| 97香蕉久久夜色精品国产| 久久中文字幕在线| 亚洲自拍偷拍一区| 欧美日韩美女在线观看| 国产精品日日摸夜夜添夜夜av| 欧美电影在线观看网站| 岛国av一区二区在线在线观看| 日韩av成人在线| 成人在线观看视频网站| 黑人狂躁日本妞一区二区三区| 中文在线资源观看视频网站免费不卡| 激情成人在线视频| 亚洲精品在线不卡| 最新国产精品亚洲| 久久久噜噜噜久久久| 日韩中文字幕视频在线观看| 2019国产精品自在线拍国产不卡| 国产精品久久一区主播| 国产精品国模在线| 亚洲欧美日韩中文在线| 欧美日韩亚洲天堂| 欧美电影免费观看大全| 久久久中精品2020中文| 国产精品久久77777| 国产日韩专区在线| 久久久免费高清电视剧观看| 日韩欧美精品在线观看| 一区二区三区动漫| 国产精品国产三级国产aⅴ9色| 欧美黄网免费在线观看| 成人av在线网址| 午夜精品国产精品大乳美女| 欧美大片大片在线播放| 亚洲精品视频久久| 欧美性视频在线| 在线观看国产精品91| 成人激情在线观看| 国产成人精品国内自产拍免费看| 日韩有码在线播放| 国产成人综合久久| 日韩精品中文字幕有码专区| 一区二区在线免费视频| www.欧美三级电影.com| 成人妇女淫片aaaa视频| 久久天天躁狠狠躁老女人| 国产日韩欧美日韩大片| 欧美黄色小视频| 综合激情国产一区| 91精品久久久久久久久久入口| 久久久国产视频| 欧美极品在线播放| 国产一区二区三区在线看| 欧美精品做受xxx性少妇| 欧美在线国产精品| 91免费国产视频| 少妇av一区二区三区| 国产精品免费久久久久影院| 久久国产精品免费视频| 国产精品日韩欧美大师| 中文字幕亚洲无线码在线一区| 国产精品wwwwww| 亚洲自拍偷拍视频| 国产日韩中文在线| 欧美成aaa人片免费看| 色无极影院亚洲| www.欧美三级电影.com| 精品国产乱码久久久久久婷婷| 久久91超碰青草是什么| 欧美亚洲日本黄色| 国产精品一二三视频| 国产欧美最新羞羞视频在线观看| 91中文在线观看| 日韩精品在线免费| 欧美第一黄色网| 亚洲国产一区自拍| 亚洲乱码一区二区| 爽爽爽爽爽爽爽成人免费观看| 91黑丝高跟在线| 欧美成人黄色小视频| 91精品国产高清久久久久久久久| 精品日韩视频在线观看| 午夜精品福利电影| 亚洲精选在线观看| 精品视频一区在线视频| 久久夜精品香蕉| 亚洲欧美国内爽妇网| 国产成人精品在线| 久久精品视频在线观看| 日日狠狠久久偷偷四色综合免费| 国产欧美一区二区三区在线| 国内伊人久久久久久网站视频| 国产精品一区电影| 久久影院中文字幕| 欧美日韩国产一区中文午夜| 国产精品久久久久免费a∨| 国产精品视频一区二区高潮| 欧美人交a欧美精品| 一本大道久久加勒比香蕉| 亚洲一级一级97网| 国产国产精品人在线视| 伊人男人综合视频网| 日本国产欧美一区二区三区| 亚洲影院污污.| 欧美激情精品久久久久久大尺度| 欧美精品性视频| 欧美视频一区二区三区…| www国产亚洲精品久久网站| 97久久久免费福利网址| 7777kkkk成人观看| 国产精品永久免费观看| 成人免费网视频| 欧美日韩第一视频| 成人黄色在线观看| 亚洲欧美制服中文字幕| 国产精品久久久久免费a∨| 久久精品视频在线播放| 亚洲精品一区二区久| 亚洲国产日韩欧美在线图片| 97人洗澡人人免费公开视频碰碰碰| 欧美老妇交乱视频| 欧美日韩一区二区在线播放| 97视频在线观看视频免费视频| 亚洲欧美日韩综合| 亚洲开心激情网|