欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
Ant十五大最佳實(shí)踐
作者:Eric M. Burke     來(lái)自:onjava
在Ant 出現之前,構建和部署Java應用需要使用包括特定平臺的腳本、Make文件、各種版本的IDE甚至手工操作的“大雜燴”?,F在,幾乎所有的開(kāi)源Java項目都在使用Ant,大多數公司的內部項目也在使用Ant。Ant在這些項目中的廣泛使用自然導致了讀者對一整套Ant最佳實(shí)踐的迫切需求。
本文總結了我喜愛(ài)的Ant技巧或最佳實(shí)踐,多數是從我親身經(jīng)歷的項目錯誤或我聽(tīng)說(shuō)的其他人經(jīng)歷的 “恐怖”故事中得到靈感的。比如,有人告訴我有個(gè)項目把XDoclet 生成的代碼放入帶有鎖定文件功能的版本控制工具中。當開(kāi)發(fā)者修改源代碼時(shí),他必須記住手工檢出(Check out)并鎖定所有將要重新生成的文件。然后,手工運行代碼生成器,只到這時(shí)他才能夠讓Ant編譯代碼,這一方法還存在如下一些問(wèn)題:
□ 生成的代碼無(wú)法存儲在版本控制系統中。
□ Ant(本案例中是Xdoclet)應該自動(dòng)確定下一次構建涉及的源文件,而不應由程序員手工確定。
□ Ant的構建文件應該定義好正確的任務(wù)依賴(lài)關(guān)系,這樣程序員就不必為了完成構建而不得不按照特定順序調用任務(wù)。
當我開(kāi)始一個(gè)新項目時(shí),我首先編寫(xiě)Ant構建文件。Ant文件明確地定義構建的過(guò)程,并被團隊中的每個(gè)程序員使用。本文所列的技巧基于這樣的假定:Ant構建文件是一個(gè)必須仔細編寫(xiě)的重要文件,它應在版本控制系統中得到維護,并被定期進(jìn)行重構。下面是我的十五大Ant最佳實(shí)踐。
1. 采用一致的編碼規范
Ant用戶(hù)有的喜歡有的痛恨其構建文件的XML語(yǔ)法。與其跳進(jìn)這一令人迷惑的爭論中,不如讓我們先看一些能保持XML構建文件簡(jiǎn)潔的方法。
首先也是最重要的,花費時(shí)間格式化你的XML讓它看上去很清晰。不論XML是否美觀(guān),Ant都可以工作。但是丑陋的XML很難令人讀懂。倘若你在任務(wù)之間留出空行,有規則的縮進(jìn)啃形淖植懷?0列左右,那么XML令人驚訝地易讀。再加上使用能夠高亮XML語(yǔ)法的優(yōu)秀編輯器或IDE工具,你就不會(huì )有閱讀的麻煩。
同樣,精選含意明確、容易讀懂的詞匯來(lái)命名任務(wù)和屬性。比如,dir.reports就比rpts好。特定的編碼規范并不重要,只要拿出一套規范并堅持使用就行。
2. 將build.xml放在項目根目錄中
Ant構建文件build.xml可以放在任何位置,但是放在項目頂級目錄中可以保持項目簡(jiǎn)潔。這是最常用的規范,開(kāi)發(fā)者能夠在頂級目錄中找到預期的build.xml。把構建文件放在根目錄中,也能夠使人容易了解項目目錄樹(shù)中不同目錄之間的邏輯關(guān)系。以下是一個(gè)典型的項目目錄層次:
[root dir]
| build.xml
+--src
+--lib (包含第三方 JAR包)
+--build (由 build任務(wù)生成)
+--dist (由 build任務(wù)生成)
當build.xml在頂級目錄時(shí),假設你處于項目某個(gè)子目錄中,只要輸入:ant -find compile 命令,不需要改變工作目錄就能夠以命令行方式編譯代碼。參數-find告訴Ant尋找存在于上級目錄中的build.xml并執行。
3. 使用單一的構建文件
有人喜歡將一個(gè)大項目分解成幾個(gè)小的構建文件,每個(gè)構建文件分擔整個(gè)構建過(guò)程的一小部分工作。這確實(shí)是看法不同的問(wèn)題,但是應該認識到,將構建文件分割會(huì )增加對整體構建過(guò)程的理解難度。要注意在單一構建文件能夠清楚表現構建層次的情況下不要過(guò)工程化(over-engineer)。
即使你把項目劃分為多個(gè)構建文件,也應使程序員能夠在項目根目錄下找到核心build.xml。盡管該文件只是將實(shí)際構建工作委派給下級構建文件,也應保證該文件可用。
4. 提供良好的幫助說(shuō)明
應盡量使構建文件自文檔化。增加任務(wù)描述是最簡(jiǎn)單的方法。當你輸入ant -projecthelp時(shí),你就可以看到帶有描述的任務(wù)清單。比如,你可以這樣定義任務(wù):
<target name="compile"
description="Compiles code, output goes to the build dir.">
最簡(jiǎn)單的規則是把所有你想讓程序員通過(guò)命令行就可以調用的任務(wù)都加上描述。對于一般用來(lái)執行中間處理過(guò)程的內部任務(wù),比如生成代碼或建立輸出目錄等,就無(wú)法使用描述屬性。
這時(shí),可以通過(guò)在構建文件中加入XML注釋來(lái)處理?;蛘邔?zhuān)門(mén)定義一個(gè)help任務(wù),當程序員輸入ant help時(shí)來(lái)顯示詳細的使用說(shuō)明。
<target name="help" description="Display detailed usage information">
<echo>Detailed help...</echo></target>
5. 提供清除任務(wù)
每個(gè)構建文件都應包含一個(gè)清除任務(wù),用來(lái)刪除所有生成的文件和目錄,使系統回到構建文件執行前的初始狀態(tài)。執行清空任務(wù)后還存在的文件都應處在版本控制系統的管理之下。比如:
<target name="clean"
description="Destroys all generated files and dirs.">
<delete dir="${dir.build}"/>
<delete dir="${dir.dist}"/>
</target>
除非是在產(chǎn)生整個(gè)系統版本的特殊任務(wù)中,否則不要自動(dòng)調用clean任務(wù)。當程序員僅僅執行編譯任務(wù)或其他任務(wù)時(shí),他們不需要構建文件事先執行既令人討厭又沒(méi)有必要的清空任務(wù)。要相信程序員能夠確定何時(shí)需要清空所有文件。
6. 使用ANT管理任務(wù)從屬關(guān)系
假設你的應用由Swing GUI組件、Web界面、EJB層和公共應用代碼組成。在大型系統中,你需要清晰地定義每個(gè)Java包屬于系統的哪一層。否則任何一點(diǎn)修改都要被迫重新編譯成百上千個(gè)文件。糟糕的任務(wù)從屬關(guān)系管理會(huì )導致過(guò)度復雜而脆弱的系統。改變GUI面板的設計不應造成Servlet和EJB的重編譯。
當系統變得龐大后,稍不注意就可能將依賴(lài)于客戶(hù)端的代碼引入到服務(wù)端。這是因為典型的IDE項目文件編譯任何文件都使用單一的classpath。而Ant能讓你更有效地控制構建活動(dòng)。
設計你的Ant構建文件編譯大型項目的步驟:首先,編譯公共應用代碼,將編譯結果打成JAR包文件。然后,編譯上一層的項目代碼,編譯時(shí)依靠第一步產(chǎn)生的JAR文件。不斷重復這一過(guò)程,直到最高層的代碼編譯完成。
分步構建強化了任務(wù)從屬關(guān)系管理。如果你工作在底層Java框架上,偶然引用到高層的GUI模板組件,這時(shí)代碼不需要編譯。這是由于構建文件在編譯底層框架時(shí)在源路徑中沒(méi)有包含高層GUI面板組件的代碼。
7. 定義并重用文件路徑
如果文件路徑在一個(gè)地方一次性集中定義,并在整個(gè)構建文件中得到重用,那么構建文件更易于理解。以下是這樣做的一個(gè)例子:
<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>
當項目不斷增長(cháng)構建日益復雜時(shí),這一技術(shù)越發(fā)體現出其價(jià)值。你可能需要為編譯不同層次的應用定義各自的文件路徑,比如運行單元測試的、運行應用程序的、運行Xdoclet的、生成JavaDocs的等等不同路徑。這種組件化路徑定義的方法比為每個(gè)任務(wù)單獨定義路徑要優(yōu)越得多。否則,很容易丟失任務(wù)從屬關(guān)系的軌跡。
8. 定義恰當的任務(wù)從屬關(guān)系
假設dist任務(wù)從屬于jar任務(wù),那么哪個(gè)任務(wù)從屬于compile任務(wù)哪個(gè)任務(wù)從屬于prepare任務(wù)呢?Ant構建文件最終定義了任務(wù)的從屬關(guān)系圖,它必須被仔細地定義和維護。
應該定期檢查任務(wù)的從屬關(guān)系以保證構建工作得到正確執行。大的構建文件隨著(zhù)時(shí)間推移趨向于增加更多的任務(wù),所以到最后可能由于不必要的從屬關(guān)系導致構建工作非常困難。比如,你可能發(fā)現在程序員只需編譯一些沒(méi)有使用EJB的GUI代碼時(shí)又重新生成了EJB代碼。
以“優(yōu)化”的名義忽略任務(wù)的從屬關(guān)系是另一種常見(jiàn)的錯誤。這種錯誤迫使程序員為了得到恰當的結果必須記住并按照特定的順序調用一串任務(wù)。更好的做法是:提供描述清晰的公共任務(wù),這些任務(wù)包含正確的任務(wù)從屬關(guān)系;另外提供一套“專(zhuān)家”任務(wù)讓你能夠手工執行個(gè)別的構建步驟,這些任務(wù)不提供完整的構建過(guò)程,但是讓那些專(zhuān)家用戶(hù)在快速而惱人的編碼期間能夠跳過(guò)某些步驟。
9.使用屬性
任何需要配置或可能發(fā)生變化的信息都應作為Ant屬性定義下來(lái)。對于在構建文件中多次出現的值也同樣處理。屬性既可以在構建文件頭部定義,也可以為了更好的靈活性而在單獨的屬性文件中定義。以下是在構建文件中定義屬性的樣式:
<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.jarjdom.jar.withpath=${jdom.home}/build/${jdom.jar}
用一個(gè)獨立的文件定義屬性是有好處的,它可以清晰地定義構建中的可配置部分。另外,在開(kāi)發(fā)者工作在不同操作系統的情況下,你可以在不同的平臺上提供該文件的不同版本。
10. 保持構建過(guò)程獨立
為了最大限度的擴展性,不要應用外部路徑和庫文件。最重要的是不要依賴(lài)于程序員的CLASSPATH設置。取而代之的是,在構建文件中使用相對路徑并定義自己的路徑。如果你引用了絕對路徑如C:\java\tools,其他開(kāi)發(fā)者未必使用與你相同的目錄結構,所以就無(wú)法使用你的構建文件。
如果你部署開(kāi)放源碼項目,應該提供包含編譯代碼所需的所有JAR文件的發(fā)行版本。當然,這是在遵守許可協(xié)議的基礎上。對于內部項目,相關(guān)的JAR文件都應在版本控制系統的管理中,并撿出(check out)到大家都知道的位置。
當你必須引用外部路徑時(shí),應將路徑定義為屬性。使程序員能夠用適合他們自己的機器環(huán)境的參數重載這些屬性。你也可以使用以下語(yǔ)法引用環(huán)境變量:
<property environment="env"/>
<property name="dir.jboss" value="${env.JBOSS_HOME}"/>
11. 使用版本控制系統
構建文件是一個(gè)重要的制品,應該像代碼一樣進(jìn)行版本控制。當你標記你的代碼時(shí),也應用同樣的標簽標記構建文件。這樣當你需要回溯到舊版本并進(jìn)行構建時(shí),能夠使用相應版本的構建文件。
除構建文件之外,你還應在版本控制中維護第三方JAR文件。同樣,這使你能夠重新構建舊版本的軟件。這也能夠更容易保證所有開(kāi)發(fā)者擁有一致的JAR文件,因為他們都是同構建文件一起從版本控制系統中撿出的。
通常應避免在版本控制系統中存放構建成果。倘若你的源代碼很好地得到了版本控制,那么通過(guò)構建過(guò)程你能夠重新生成任何版本的產(chǎn)品。
12. 把Ant作為“最小公分母”
假設你的開(kāi)發(fā)團隊使用IDE工具,當程序員通過(guò)點(diǎn)擊圖標就能夠構建整個(gè)應用時(shí)為什么還要為Ant而煩惱呢?
I(yíng)DE的問(wèn)題是一個(gè)關(guān)于團隊一致性和重現性的問(wèn)題。幾乎所有的IDE設計初衷都是為了提高程序員的個(gè)人生產(chǎn)率,而不是開(kāi)發(fā)團隊的持續構建。典型的IDE要求每個(gè)程序員定義自己的項目文件。程序員可能擁有不同的目錄結構,可能使用不同版本的庫文件,還可能工作在不同的平臺上。這將導致出現這種情況:在Bob那里運行良好的代碼,到Sally那里就無(wú)法運行。
不管你的開(kāi)發(fā)團隊使用何種IDE,一定要建立所有程序員都能夠使用的Ant構建文件。要建立一個(gè)程序員在將新代碼提交版本控制系統前必須執行Ant構建文件的規則。這將確保代碼是經(jīng)過(guò)同一個(gè)Ant構建文件構建的。當出現問(wèn)題時(shí),要使用項目標準的Ant構建文件,而不是通過(guò)某個(gè)IDE來(lái)執行一個(gè)干凈的構建。
程序員可以自由選擇任何他們習慣使用的IDE工具或編輯器。但是Ant應作為公共基線(xiàn)以保證代碼永遠是可構建的。
13. 使用zipfileset屬性
人們經(jīng)常使用Ant產(chǎn)生WAR、JAR、ZIP和 EAR文件。這些文件通常都要求有一個(gè)特定的內部目錄結構,但其往往與你的源代碼和編譯環(huán)境的目錄結構不匹配。
一個(gè)最常用的方法是寫(xiě)一個(gè)Ant任務(wù),按照期望的目錄結構把一大堆文件拷貝到臨時(shí)目錄中,然后生成壓縮文件。這不是最有效的方法。使用zipfileset屬性是更好的解決方案。它讓你從任何位置選擇文件,然后把它們按照不同目錄結構放進(jìn)壓縮文件中。以下是一個(gè)例子:
<ear earfile="${dir.dist.server}/payroll.ear"
appxml="${dir.resources}/application.xml">
<fileset dir="${dir.build}" includes="commonServer.jar"/>
<fileset dir="${dir.build}">
<include name="payroll-ejb.jar"/>
</fileset>
<zipfileset dir="${dir.build}" prefix="lib">
<include name="hr.jar"/>
<include name="billing.jar"/>
</zipfileset>
<fileset dir=".">
<include name="lib/jdom.jar"/>
<include name="lib/log4j.jar"/>
<include name="lib/ojdbc14.jar"/>
</fileset>
<zipfileset dir="${dir.generated.src}" prefix="META-INF">
<include name="jboss-app.xml"/>
</zipfileset>
</ear>
在這個(gè)例子中,所有JAR文件都放在EAR文件包的lib目錄中。hr.jar和billing.jar是從構建目錄拷貝過(guò)來(lái)的。因此我們使用zipfileset屬性把它們移動(dòng)到EAR文件包內部的lib目錄。prefix屬性指定了其在EAR文件中的目標路徑。
14. 測試Clean任務(wù)
假設你的構建文件中有clean和compile的任務(wù),執行以下的測試。第一步,執行ant clean;第二步,執行ant compile;第三步,再執行ant compile。第三步應該不作任何事情。如果文件再次被編譯,說(shuō)明你的構建文件有問(wèn)題。
構建文件應該只在與輸出文件相關(guān)聯(lián)的輸入文件發(fā)生變化時(shí)執行任務(wù)。一個(gè)構建文件在不必執行諸如編譯、拷貝或其他工作任務(wù)的時(shí)候執行這些任務(wù)是低效的。當項目規模增長(cháng)時(shí),即使是小的低效工作也會(huì )成為大的問(wèn)題。
15. 避免特定平臺的Ant封裝
不管什么原因,有人喜歡用簡(jiǎn)單的、名稱(chēng)叫做compile之類(lèi)的批文件或腳本裝載他們的產(chǎn)品。當你去看腳本的內容你會(huì )發(fā)現以下內容:
ant compile
其實(shí)開(kāi)發(fā)人員都很熟悉Ant,并且完全能夠自己鍵入ant compile。請不要僅僅為了調用Ant而使用特定平臺的腳本。這只會(huì )使其他人在首次使用你的腳本時(shí)增加學(xué)習和理解的煩擾。除此之外,你不可能提供適用于每個(gè)操作系統的腳本,這是真正煩擾其他用戶(hù)的地方。
總結
太多的公司依靠手工方法和特別程序來(lái)編譯代碼和生成軟件發(fā)布版本。那些不使用Ant或類(lèi)似工具定義構建過(guò)程的開(kāi)發(fā)團隊,花費了太多的時(shí)間來(lái)捕捉代碼編譯過(guò)程中出現的問(wèn)題:在某些開(kāi)發(fā)者那里編譯成功的代碼,到另一些開(kāi)發(fā)者那里卻失敗了。
生成并維護構建腳本不是一項富有魅力的工作,但卻是一項必需的工作。一個(gè)好的Ant構建文件將使你能夠集中到更喜歡的工作——寫(xiě)代碼中去!
參考
☆http://ant.apache.org/  Ant
☆http://www.ericburke.com/  AntGraph: Ant依賴(lài)性的可視化工具
☆http://www.oreilly.com/catalog/anttdg/index.html?CMP=IL7015  Ant: The Definitive Guide, O‘Reilly
☆http://www.oreilly.com/catalog/jextprockbk/index.html?CMP=IL7015  Java Extreme Programming Cookbook, O‘Reilly
原文:http://www.onjava.com/pub/a/onjava/2003/12/17/ant_bestpractices.html
翻譯:徐彤 MSN:xt121@hotmail.com
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
使用 Ant 自動(dòng)生成項目構建版本
ant教程詳解--javac,java,jar,war,delete,copy,mkdir...
ANT打包編譯部署工具學(xué)習筆記
Hibernate代碼生成初接觸之Middlegen生成hbm文件和java代碼
Ant教程
Ant簡(jiǎn)介
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久