1.Eclipse
成都創(chuàng)新互聯(lián)服務(wù)項目包括硚口網(wǎng)站建設(shè)、硚口網(wǎng)站制作、硚口網(wǎng)頁制作以及硚口網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,硚口網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到硚口省份的部分城市,未來相信會繼續(xù)擴大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
盡管IntelliJ IDEA、NetBeans和一些其他的IDE正在日益普及,但是有調(diào)查表明,Eclipse仍然是幾乎半數(shù)Java開發(fā)人員首選的開發(fā)環(huán)境。 Eclipse是IDE領(lǐng)域的瑞士軍刀,有著大量定制的接口和無數(shù)的插件。它無處不在,后面本文將推薦的其他所有工具都提供Eclipse插件。
Eclipse的工作流程可分為三個方面:工作臺,工作空間和視角。工作臺作為到IDE的出發(fā)點。工作空間將項目、文件和配置設(shè)置組合在一個單獨的 目錄下。視角定義工具、視圖和有效設(shè)置。雖然新手開發(fā)人員可能會覺得相比Netbeans和IntelliJ IDEA,Eclipse使用起來更難,但Eclipse的靈活性,使其成為企業(yè)開發(fā)的首選IDE。
Luna,Eclipse的最新版本,支持Java 8、分屏編輯、新的黑色主題,以及一個功能齊全的命令行終端。
官方網(wǎng)站:
2.Gradle
Gradle是一個自動化項目工具,建立在Apache Maven和Apache Ant的功能上。雖然Gradle并不是最流行的構(gòu)建工具(最流行的是Maven,64%的Java開發(fā)人員會選擇它),但它的普及速度很快。它也可作為默認(rèn)的Android構(gòu)建工具。
Gradle引以為傲的是它的簡單。Gradle使用Groovy編程語言,與Maven和Ant使用XML語法截然相反。一個基本的Gradle構(gòu)建文件由一行簡單的代碼組成:
apply plugin: 'java'.
下面的命令會生成一個Gradle構(gòu)建文件,創(chuàng)建項目文件的目錄樹,并附帶一個項目便攜式Gradle封裝:
$ gradle init --type java-library
Gradle還有可用于添加新的語言,生成支持IDE的項目文件,構(gòu)建本地二進制文檔,檢查依賴性更新等等的插件。
想要了解更多信息,請參見Gradle的Java / JVM入門指南。
官方網(wǎng)站:
3.Javadoc
Javadoc是Oracle提供的文檔生成器。它可以將特殊格式的注釋解析為HTML文檔。以下截圖就是Javadoc生成的Java SE 8 API規(guī)范:
Javadoc注釋使用開放標(biāo)簽、關(guān)閉標(biāo)簽,以及一個或多個描述性標(biāo)簽的格式。開放式標(biāo)簽類似于標(biāo)準(zhǔn)Java多行注釋標(biāo)記,使用兩個星號的除外。Javadoc也解析普通的HTML標(biāo)簽。
Javadoc自動格式化標(biāo)簽和關(guān)鍵字,除非另有規(guī)定。Javadoc廣泛使用超鏈接,允許你參考和鏈接到代碼的不同區(qū)域。許多IDE——包括 Eclipse——可以自動添加Javadoc注釋模塊到變量、類和方法中。支持Maven、Gradle和Ant的插件在編譯代碼的同時也可以構(gòu)建 Javadoc HTML。
想要了解更多信息,請參閱Oracle關(guān)于如何為Javadoc工具寫文檔注釋的文章。
官方網(wǎng)站:
4.JUnit
JUnit是用于編寫和運行單元測試的開源框架。一個基本的JUnit測試包括測試類、測試方法、以及執(zhí)行測試的功能。 JUnit使用標(biāo)注來確定測試如何構(gòu)造和運行。例如,如果你的程序有一個類叫做MathClass,具有乘法和除法的方法,你可以創(chuàng)建JUnit測試來檢 查不符合預(yù)期的值。輸入數(shù)字2和5到乘法方法,你希望得到的結(jié)果為10。當(dāng)輸入0作為除法方法的第二個參數(shù)時,你會期望給出一個數(shù)字計算異常的警告因為除 數(shù)不能為0:
@Test標(biāo)注規(guī)定,MathClass方法是一個測試用例。 在JUnit提供額外的標(biāo)注,比如@Before,這樣你就可以在測試運行之前設(shè)置環(huán)境。 JUnit還可以設(shè)置規(guī)則用于定義測試方法的行為。例如,TemporaryFolder規(guī)則使得一旦測試完成,由測試創(chuàng)建的文件或文件夾就會被刪除。
想要了解更多信息,請參考JUnit入門。 此外還有使用JUnit單元測試的教程。
官方網(wǎng)站:
5.Cobertura
Cobertura可用于分析Java代碼的測試覆蓋率。Cobertura根據(jù)沒有被測試覆蓋的代碼生成基于HTML的報告。
Cobertura提供可用于插裝、檢查和測試代碼的工具。通過監(jiān)控可測試的代碼,Cobertura允許你使用你選擇的測試框架,甚至不需要測試框架就可以運行程序。
Cobertura根據(jù)行、分支和程序包三個方面給出代碼覆蓋報告。每個類別都有一個可自定義的閾值,如果覆蓋面低于閾值,就會觸發(fā)警告。Cobertura還集成了Maven和Gradle 的自動檢測功能。
Mkyong.com提供了一個將Cobertura與Maven整合的示例。
官方網(wǎng)站:
6.FindBugs
FindBugs是一個匹配編譯代碼模式,而非使用bug數(shù)據(jù)庫的工具。當(dāng)提供源代碼時,F(xiàn)indBugs還可高亮顯示檢測出bug的代碼行。
在它的3.0.1版本中,F(xiàn)indBugs繼續(xù)保持著數(shù)以百計的bug描述。根據(jù)bug的嚴(yán)重程度,F(xiàn)indBugs將bug分為四個水平:相關(guān) 的,令人困擾的,可怕的,以及最可怕的。除了圖形用戶界面,F(xiàn)indBugs還提供一個命令行界面,Ant任務(wù),以及Eclipse插件。
官方網(wǎng)站:
7.VisualVM
包含在JDK中的VisualVM是監(jiān)控和審查Java應(yīng)用程序性能的工具。 VisualVM檢測并重視活躍的JVM實例來檢索有關(guān)進程的診斷信息。
VisualVM可以很容易地實時診斷性能問題。它提供了全套的分析工具,包括JConsole、jstack、jmap、jinfo和jstat等。此外,你還可以對JVM做一個快照,這樣以后在任何時都能審查。
官方網(wǎng)站:
8.Groovy
Groovy是一種編程語言,通過添加新的關(guān)鍵字,自動導(dǎo)入常用的類,以及可選類型變量聲明,既簡化又?jǐn)U展了Java。
Groovy的核心優(yōu)勢之一是它的腳本功能。類可以被編譯為Java字節(jié)碼或使用Groovy Shell動態(tài)執(zhí)行。Groovy的Java基礎(chǔ)使得它相較于Jython和JRuby更容易為Java開發(fā)人員所接受。
想要了解更多信息,請參見Groovy的入門指南。
官方網(wǎng)站:
1、VisualVM
VisualVM是一個資源分析工具,一直從JDK 6更新到7。它默認(rèn)內(nèi)存和CPU的監(jiān)視。它可以告訴你哪個類和方法消耗資源,但它不會顯示代碼流程。
2、JProfiler
JProfiler很容易安裝,并且通過向?qū)?,你可以選擇應(yīng)用服務(wù)器用來運行應(yīng)用程序。我不得不選擇使用JPofiler應(yīng)用服務(wù)器的主目錄,以及向?qū)傻囊粋€單獨的啟動腳本。然后運行服務(wù)器。在監(jiān)聽會話的過程中,它會提供了幾個選項。它可以記錄內(nèi)存的使用和CPU的使用率。在查看CPU的使用率同時,可以看到執(zhí)行路徑。這讓我看到應(yīng)用程序大部分時間都花在請求上。我們可以將IntelliJ插件安裝到IDE上,那么運行JProfiler會更加便利。比如,可以直接幫我啟動Tomcat。
3、YourKit
YourKit是我在另一個項目中偶然發(fā)現(xiàn)的一款性能分析工具。它的安裝很簡單。安裝時有一個選項,可以安裝一個插件到我的IDE。安裝后,運行應(yīng)用程序,使用該插件,它會自動連接到Y(jié)ourKit。它有一個漂亮的用戶界面可以查看到內(nèi)存和CPU的監(jiān)測,同時也可以看到請求的執(zhí)行路徑。
4、JProbe
我剛開始創(chuàng)建JProbe時遇到點困難。安裝并不是直接完成,我需要對它進行配置。它采用了類似JProfiler一樣的設(shè)置。它會在你的Tomcat目錄中生成啟動腳本??梢酝ㄟ^腳本啟動服務(wù)器并監(jiān)聽會話。它的界面包含有按鈕和表格,其中可以看到內(nèi)存的使用,但無法在進程中找到執(zhí)行路徑。
5、Spring Insight
聽到TC Server有Spring Insight監(jiān)控界面,于是我興奮地嘗試了一下。安裝完成后,并設(shè)置成TC Server的開發(fā)者版,然后部署應(yīng)用程序在TC Server上。我查看Insight界面,它可以很好的監(jiān)視類和方法,并能看到完成這個方法用了多少時間。我還能看到輸入?yún)?shù)值,以及返回值。由于我的應(yīng)用程序是基于Spring的,Spring Insight能夠提供非常有用的數(shù)據(jù)。TC Server插件在IDE上的配置與Tomcat的配置類似。SpringSource工具套件就自帶Spring Insight。
結(jié)論
看到這五款性能分析工具,我可以肯定地說,它們都非常不錯。如果你有基于Spring的應(yīng)用程序,那么選擇Spring Insight顯然是最佳的。它一直是免費的,但你需要部署你的應(yīng)用在TC Server上。
如果你想監(jiān)聽本地和遠程的進程,我會選擇JProfiler或YourKit。這兩個也可以幫助Spring Insight來監(jiān)測、找到性能瓶頸。
JProfiler和YourKit已經(jīng)能滿足我的上述要求。JProfiler、YourKit和Spring Insight都可以跟蹤應(yīng)用程序的類和方法的流向。JProfiler和YourKit可以顯示內(nèi)存使用情況。雖然Spring Insight不可以顯示內(nèi)存使用情況,但它可以很好的顯示吞吐量的趨勢。這三款性能分析工具功能很清楚,不混亂,而且容易使用。最后,他們都有自己的IDE插件。希望本文能幫助你做出正確的選擇。
常用的工具有:
Eclipse ? 據(jù)數(shù)據(jù)顯示很多Java開發(fā)人員的Java開發(fā)工具便是Eclipse,這主要得益于Eclipse是一個開源的、可以基于Java的可擴展開發(fā)平臺。Eclipse本身而言,它只是一個框架和一組服務(wù),但可以通過插件組件構(gòu)建開發(fā)環(huán)境。
editplus ?EditPlus是一款由韓國 Sangil Kim (ES-Computing)開發(fā)的編輯器,可以作為C,Java,Php等等語言的一個簡單的IDE。EditPlus擁有無限制的撤消與重做、英文拼字檢查、自動換行、列數(shù)標(biāo)記、搜尋取代、同時編輯多文件、全屏幕瀏覽功能,也是一款常見的Java開發(fā)工具。
NetBeans ? NetBeans提供了功能全面的陣列,如轉(zhuǎn)換器,編輯器和代碼分析器,使用這些工具可以幫助我們使用的Java技術(shù)實現(xiàn)應(yīng)用程序。NetBeans工具范圍相當(dāng)廣泛,是一款的Java開發(fā)工具。
Junit ? ?Junit是一個可以幫助Java開發(fā)人員編寫和運行測試的單元測試框架。JUnit和市場上其他類似的框架有著本質(zhì)的區(qū)別。主要表現(xiàn)在你可以一次測試一個代碼塊,而不需要等待該模塊在運行測試前完成。實際上是你可以“先測試,然后寫代碼”
VisualVM ? ?VisualVM也是一款使用較多的Java開發(fā)工具。它最主要的功能便是可以排查故障,可以使用VisualVM整合多命令行JDK工具。如jvmstat、JMX和Serviceability Agent(SA)中使用VisualVM。VisualVM最出名的是附加了API,以獲得更多的數(shù)據(jù),以及自動使用更快捷。
Gradle ? ?Gradle是一個自動化項目工具,是建立在Apache Maven和Apache Ant的功能上。雖然Gradle并不是的構(gòu)建工具(的是Maven,64%的Java開發(fā)人員會選擇它),但它的普及速度很快。它同時也可作為默認(rèn)的Android構(gòu)建開發(fā)工具。
SparkJava ? ?SparkJava是一款體形輕巧,功能強大的Web應(yīng)用框架。Spark可以通過一些繁瑣的XML配置來使用Spark框架編寫應(yīng)用程序。能讓我們花最少的精力來開發(fā)Java的Web應(yīng)用程序。是一款的Java web開發(fā)工具。
Clover ? ?Clover主要用于代碼覆蓋,可以幫助用于測試應(yīng)用程序的代碼。我們可以在IDE或持續(xù)集成系統(tǒng)中運行Clover。能夠讓測試的運行速度更快。是Java開發(fā)測試必不可少的工具之一。
常見的十四種Java開發(fā)工具的特點
1、JDK(JavaDevelopmentKit)Java開發(fā)工具集
從初學(xué)者角度來看,采用JDK開發(fā)Java程序能夠很快理解程序中各部分代碼之間的關(guān)系,有利于理解Java面向?qū)ο蟮脑O(shè)計思想。JDK的另一個顯著特點是隨著Java(J2EE、J2SE以及J2ME)版本的升級而升級。但它的缺點也是非常明顯的就是從事大規(guī)模企業(yè)級Java應(yīng)用開發(fā)非常困難,不能進行復(fù)雜的Java軟件開發(fā),也不利于團體協(xié)同開發(fā)。
2、JavaWorkshop
3、NetBeans與SunJavaStudio5
NetBeans是開放源碼的Java集成開發(fā)環(huán)境(IDE),適用于各種客戶機和Web應(yīng)用。
SunJavaStudio是Sun公司最新發(fā)布的商用全功能JavaIDE,支持Solaris、Linux和Windows平臺,適于創(chuàng)建和部署2層JavaWeb應(yīng)用和n層J2EE應(yīng)用的企業(yè)開發(fā)人員使用。NetBeans是業(yè)界第一款支持創(chuàng)新型Java開發(fā)的開放源碼IDE。開發(fā)人員可以利用業(yè)界強大的開發(fā)工具來構(gòu)建桌面、Web或移動應(yīng)用。同時,通過NetBeans和開放的API的模塊化結(jié)構(gòu),第三方能夠非常輕松地擴展或集成NetBeans平臺。NetBeans3.5.1主要針對一般Java軟件的開發(fā)者,而JavaOneStudio5則主要針對企業(yè)做網(wǎng)絡(luò)服務(wù)等應(yīng)用的開發(fā)者。Sun不久還將推出ProjectRave,其目標(biāo)是幫助企業(yè)的開發(fā)者進行軟件開發(fā)。NetBeans3.5.1版本與其他開發(fā)工具相比,最大區(qū)別在于不僅能夠開發(fā)各種臺式機上的應(yīng)用,而且可以用來開發(fā)網(wǎng)絡(luò)服務(wù)方面的應(yīng)用,可以開發(fā)基于J2ME的移動設(shè)備上的應(yīng)用等。在NetBeans3.5.1基礎(chǔ)上,Sun開發(fā)出了JavaOneStudio5,為用戶提供了一個更加先進的企業(yè)編程環(huán)境。在新的JavaOneStudio5里有一個應(yīng)用框架,開發(fā)者可以利用這些模塊快速開發(fā)自己在網(wǎng)絡(luò)服務(wù)方面的各種應(yīng)用程序。
4、Borland的JBuilder
Jbuilder進入了Java集成開發(fā)環(huán)境的王國,它滿足很多方面的應(yīng)用,尤其是對于服務(wù)器方以及EJB開發(fā)者們來說。下面簡單介紹一下Jbuilder的特點:
1)Jbuilder支持最新的Java技術(shù),包括Applets、JSP/Servlets、JavaBean以及EJB(EnterpriseJavaBeans)的應(yīng)用。
2)用戶可以自動地生成基于后端數(shù)據(jù)庫表的EJBJava類,Jbuilder同時還簡化了EJB的自動部署功能.此外它還支持CORBA,相應(yīng)的向?qū)С绦蛴兄谟脩羧娴毓芾鞩DL(分布應(yīng)用程序所必需的接口定義語言InterfaceDefinitionLanguage)和控制遠程對象。
3)Jbuilder支持各種應(yīng)用服務(wù)器。Jbuilder與InpriseApplicationServer緊密集成,同時支持WebLogicServer,支持EJB1.1和EJB2.0,可以快速開發(fā)J2EE的電子商務(wù)應(yīng)用。
4)Jbuilder能用Servlet和JSP開發(fā)和調(diào)試動態(tài)Web應(yīng)用。
5)利用Jbuilder可創(chuàng)建(沒有專有代碼和標(biāo)記)純Java2應(yīng)用。由于Jbuilder是用純Java語言編寫的,其代碼不含任何專屬代碼和標(biāo)記,它支持最新的Java標(biāo)準(zhǔn)。
6)Jbuilder擁有專業(yè)化的圖形調(diào)試介面,支持遠程調(diào)試和多線程調(diào)試,調(diào)試器支持各種JDK版本,包括J2ME/J2SE/J2EE。JBuilder環(huán)境開發(fā)程序方便,它是純的Java開發(fā)環(huán)境,適合企業(yè)的J2EE開發(fā);缺點是往往一開始人們難于把握整個程序各部分之間的關(guān)系,對機器的硬件要求較高,比較吃內(nèi)存,這時運行速度顯得較慢。
5、Oracle的JDeveloper
Oracle9iJDeveloper(定為9.0版,最新為10g)為構(gòu)建具有J2EE功能,XML和Webservices的復(fù)雜的,多層的Java應(yīng)用程序提供了一個完全集成的開發(fā)環(huán)境。它為運用Oracle9i數(shù)據(jù)庫和應(yīng)用服務(wù)器的開發(fā)人員提供特殊的功能和增強性能,除此以外,它也有資格成為用于多種用途Java開發(fā)的一個強大的工具。
Oracle9iJDeveloper的主要特點如下:
①具有UML(UnifiedModelingLanguage,一體化建模語言)建模功能。可以將業(yè)務(wù)對象及e-business應(yīng)用模型化。
②配備有高速Java調(diào)試器(Debuger)、內(nèi)置Profiling工具、提高代碼質(zhì)量的工具“CodeCoach”等。
③支持SOAP(SimpleObjectAccessProtocol)“簡單對象訪問協(xié)議”、UDDI(UniversalDescription,DiscoveryandIntegration)“統(tǒng)一描述、發(fā)現(xiàn)和集成協(xié)議”
、WSDL(WebServicesDescriptionLanguage)“WEB服務(wù)描述語言”等Web服務(wù)標(biāo)準(zhǔn)。JDeveloper不僅僅是很好的Java編程工具,而且是OracleWeb服務(wù)的延伸,支持ApacheSOAP,以及9iAS,可擴充的環(huán)境和XML和WSDL語言緊密相關(guān)。Oracle9iJdeveloper完全利用Java編寫,能夠與以前的Oracle服務(wù)器軟件以及其他廠商支持J2EE的應(yīng)用服務(wù)器產(chǎn)品相兼容,而且在設(shè)計時著重針對Oracle9i,能夠無縫化跨平臺之間的應(yīng)用開發(fā),提供了業(yè)界第一個完整的、集成了J2EE和XML的開發(fā)環(huán)境,允許開發(fā)者快速開發(fā)可以通過Web、無線設(shè)備及語音界面訪問的Web服務(wù)和交易應(yīng)用,以往只能通過將傳統(tǒng)Java編程技巧與最新模塊化方式結(jié)合到一個單一集成的開發(fā)環(huán)境中之后才能完成J2EE應(yīng)用開發(fā)生命周期管理的事實,從根本上得到改變。缺點就是對于初學(xué)者來說,較復(fù)雜,也比較難。
6、IBM的VisualAgeforJava
VisualAgeforJava是一個非常成熟的開發(fā)工具,它的特性以于IT開發(fā)者和業(yè)余的Java編程人員來說都是非常用有用的。它提供對可視化編程的廣泛支持,支持利用CICS連接遺傳大型機應(yīng)用,支持EJB的開發(fā)應(yīng)用,支持與Websphere的集成開發(fā),方便的bean創(chuàng)建和良好的快速應(yīng)用開發(fā)(RAD)支持和無文件式的文件處理。
IBM為建設(shè)Web站點所推出的WebSphereStudioAdvancedEdition及其包含的Visual
AgeforJavaProfessionalEdition軟件已全面轉(zhuǎn)向以Java為中心,這樣,Java開發(fā)人員對WebSphere全套工具的感覺或許會好了許多。Studio所提供的工具有:Web站點管理、快速開發(fā)JDBC頁向?qū)С绦?、HTML編輯器和HTML語法檢查等。這確實是個不錯的HTML站點頁面編輯環(huán)境。Studio和VisualAge集成度很高,菜單中提供了在兩種軟件包之間快速移動代碼的選項。這就讓使用Studio的Web頁面設(shè)計人員和使用VisualAge的Java程序員
可以相互交換文件、協(xié)同工作。VisualAgeforJava支持團隊開發(fā),內(nèi)置的代碼庫可以自動地根據(jù)用戶做出改動而修改程序代碼,這樣就可以很方便地將目前代碼和早期版本做出比較。與VisualAge緊密結(jié)合的WebsphereStudio本身并不提供源代碼和版本管理的支持,它只是包含了一個內(nèi)置文件鎖定系統(tǒng),當(dāng)編輯項目的時候可以防止其他人對這些文件的錯誤修改,軟件還支持諸如MicrosoftVisualSourceSafe這樣的第三方源代碼控制系統(tǒng)。VisualAgeforJava完全面向?qū)ο蟮某绦蛟O(shè)計思想使得開發(fā)程序非??焖?、高效。你可以不編寫任何代碼就可以設(shè)計出一個典型的應(yīng)用程序框架。VisualAgeforJava作為IBM電子商務(wù)解決方案其中產(chǎn)品之一,可以無縫地與其他IBM產(chǎn)品,如WebSphere、DB2融合,迅速完成從設(shè)計、開發(fā)到部署應(yīng)用的整個過程。VisualAgeforJava獨特的管理文件方式使其集成外部工具非常困難,你無法讓VisualAgeforJava與其他工具一起聯(lián)合開發(fā)應(yīng)用。
7、BEA的WebLogicWorkshop
BEAWebLogicWorkshop是一個統(tǒng)一、簡化、可擴展的開發(fā)環(huán)境,使所有的開發(fā)人員都能在BEAWebLogicEnterprisePlatform之上構(gòu)建基于標(biāo)準(zhǔn)的企業(yè)級應(yīng)用,從而提高了開發(fā)部門的生產(chǎn)力水平,加快了價值的實現(xiàn)。WebLogicWorkshop除了提供便捷的Web服務(wù)之外,它能夠用于創(chuàng)建更多種類的應(yīng)用。作為整個BEAWebLogicPlatform的開發(fā)環(huán)境。不管是創(chuàng)建門戶應(yīng)用、編寫工作流、還是創(chuàng)建Web應(yīng)用,Workshop8.1都可以幫助開發(fā)人員更快更好地完成。WebLogicWorkshop的主要特點如下:
①使J2EE開發(fā)切實可行,提高開發(fā)效率
BEAWebLogicWorkshop使開發(fā)人員遠離J2EE內(nèi)在的復(fù)雜性,集中精力專注業(yè)務(wù)邏輯,無須操心單調(diào)乏味的基礎(chǔ)結(jié)構(gòu)代碼。這種創(chuàng)新意味著,已被企業(yè)驗證的J2EE的強大功能,最終被大多數(shù)不熟悉Java和J2EE的應(yīng)用開發(fā)人員所掌握,從而使IT部門的工作效率提高一個數(shù)量級。可視化設(shè)計器以及直觀的概念,如事件、屬性和控件等,實現(xiàn)了基于事件的開發(fā)。Workshop簡化的程序設(shè)計模型,使開發(fā)人員不必掌握復(fù)雜的J2EEAPI和面向?qū)ο蟮某绦蛟O(shè)計原理。所有開發(fā)人員,包括J2EE專家和具有可視化和過程化語言技能的應(yīng)用開發(fā)人員在內(nèi),都可以共同工作在BEAWebLogicEnterprisePlatform之上。Workshop的可視化開發(fā)環(huán)境,創(chuàng)建帶有代碼注釋的標(biāo)準(zhǔn)Java文件,用來說明由運行時框架實施的企業(yè)級需求。J2EE和其他高級開發(fā)人員,借助功能強大的代碼編輯功能,可以訪問Java源代碼,從而彌補了可視化設(shè)計器的不足。
②構(gòu)建企業(yè)級應(yīng)用
通過在可伸縮、安全可靠的企業(yè)級架構(gòu)上實施各種應(yīng)用,BEAWebLogicWorkshop大大降低了開發(fā)風(fēng)險。而且,所有應(yīng)用的創(chuàng)建都使用標(biāo)準(zhǔn)的J2EE組件,既保護了您的技術(shù)投資,又保持了最大的靈活性。BEAWebLogicWorkshop運行框架,是統(tǒng)一整個架構(gòu)的匯聚層,使單一、簡化的程序設(shè)計模型擴展到所有的BEAWebLogicEnterprisePlatform應(yīng)用類型。通過解釋設(shè)計時創(chuàng)建的注釋代碼,運行時框架可以實現(xiàn)必要的J2EE組件,并且提取出與J2EE應(yīng)用開發(fā)有關(guān)的所有底層細節(jié)。
③降低IT復(fù)雜性BEAWebLogicWorkshop提供各種Java控件,使得與IT資源的連接更輕而易舉。另外,在構(gòu)建任何BEAWebLogicPlatform的應(yīng)用中,Java控件不僅可擴展而且完全相同。這種強大、有效的方法能夠:降低IT技術(shù)的復(fù)雜性,優(yōu)化信息的可用性,推動包含"最佳業(yè)務(wù)方案"的可重用服務(wù)的開發(fā),使開發(fā)人員能以更低的成本、更短的時間實現(xiàn)更大的產(chǎn)出。
利用BEAWebLogicWorkshop,任何開發(fā)人員都能以最大的生產(chǎn)效率,構(gòu)建各種Web服務(wù)、Web應(yīng)用、門戶和集成項目。BEAWebLogicWorkshop是BEA的產(chǎn)品戰(zhàn)略核心,它幫助客戶接觸和利用面向服務(wù)架構(gòu)(SOA)的強大功能。BEAWeblogicWorkshop8.1極大簡化了當(dāng)前實際企業(yè)集成環(huán)境中企業(yè)級應(yīng)用和服務(wù)的構(gòu)建,并成為全面支持關(guān)鍵企業(yè)級應(yīng)用(如異步、真正松耦合和粗粒度消息傳送等)的自然選擇。它的缺點就是過于復(fù)雜,對于初學(xué)者來說,理解起來較為困難。
8、WebGain的VisualCafeforJavaVisualCafe是只能在Symantec公司的Java虛擬機、Netscape公司的Java虛擬機和Microsoft虛擬機上工作的調(diào)試器。這對于開發(fā)者來講是一個重要的特性,因為用戶開發(fā)的Java代碼中的許多軟件bug就可能中會在某種特定的虛擬機上起作用。在修改后進行編譯基繼續(xù)進行調(diào)試時,VisualCafe會自動將文件存盤,使用VisualCafe創(chuàng)建的原生應(yīng)用具有許多特點。除了明顯的速度提高之外,Symantec使類庫的二進制方式比正常的JDK小VisualCafe為所指定的關(guān)系自動生成或更新必要的Java代碼。利用VisualCafe,用戶可以從一個標(biāo)準(zhǔn)對象數(shù)據(jù)庫中集合完整的Java應(yīng)用程序和Applet,而不必再編寫源代碼。VisualCafe還提供了一個擴充的源代碼開發(fā)工具集。VisualCafe綜合了Java軟件的可視化源程序開發(fā)工具,它允許開發(fā)人員在可視化視圖和源視圖之間進行有效地轉(zhuǎn)換。在可視化視圖中進行的修改立即反映在源代碼中。對源代碼的改變自動更新可視化視圖。VisualCafe具有許多源文件方面的特性,如全局檢索和替換。絕大多數(shù)Java開發(fā)工具的文獻的問題在于簡單地挨個介紹開發(fā)工具的每部分組件,但用戶在開應(yīng)用時還需要一個面向任務(wù)的手冊,利用這個手冊你可以不必知道工具每一部分的特定功能就可以開始創(chuàng)建自己的應(yīng)用。VisualCafe提供了非常全面的用戶指南,它對最開始的安裝到創(chuàng)建第一個Java應(yīng)用和Applet都提供了全面的幫助,VisualCafe將自動生成所指明關(guān)系的必要Java代碼。VisualCafe可以在Windows95和WindowsNT平臺下運行,Symantec公司為Java開發(fā)工作提供一個在Macintosh操作系統(tǒng)下可以運行的RAD工具。VisualCafe編譯器速度很快,在國際化支持方面比較突出;缺點就是對于初學(xué)者來說,較復(fù)雜,也比較難。
9、Macromedia的JRUN
Macromedia公司的JRun是一個具有最廣闊適用性的Java引擎,用于開發(fā)及實施由JavaServlets和JavaServerPages編寫的服務(wù)器端Java應(yīng)用。JRun是第一個完全支持JSP1.0規(guī)格書的商業(yè)化產(chǎn)品,全球有超過80,000名開發(fā)人員使用JRun在他們已有的Web服務(wù)器上添加服務(wù)器端Java的功能。其中Web服務(wù)器包括了MicrosoftIIS,NetscapeEnterpriseServer,Apache等。JRun是開發(fā)實施服務(wù)器端Java的先進引擎。如果我們希望在我們的Web應(yīng)用中添加服務(wù)器端Java功能,那么JRun將成為我們的正確選擇。JRun目前有3個版本,它是第一個支持JavaServerPages(JSP)規(guī)格書1.0的商業(yè)化產(chǎn)品。JSP是一種強大的服務(wù)器端技術(shù),它是用于創(chuàng)建復(fù)雜Web應(yīng)用的一整套快速應(yīng)用開發(fā)系統(tǒng)。JRun可以使我們開始開發(fā)并測試Java應(yīng)用。它最多接受5個并發(fā)的連接并且包括全部JavaServletAPI,支持JavaServerPages(JSP),支持所有主要的Webservers和計算機平臺。JRunPro能夠在生產(chǎn)環(huán)境下承受大訪問量的負(fù)載,幫助我們實施應(yīng)用、服務(wù)或Web站點(包括內(nèi)聯(lián)網(wǎng))。JRunPro支持無限量并發(fā)式連接運行多個Java虛擬機,包括多個并發(fā)的Java虛擬機(JVM)。提供一個遠程管理applet以及一個遠程可再分布式的管理applet。JRunProUnlimited包括了所有JRunPro的功能,除次以外,還可以運行無限量的,并發(fā)的JVM。JRun依靠其內(nèi)置的JRunWebServer可以單獨運行。使用服務(wù)器端Java,用戶可以開發(fā)出復(fù)雜的商業(yè)應(yīng)用系統(tǒng)。最重要的一點是,由于servlets的平臺獨立性,以及更加簡單的開發(fā)、更快速的實施、更經(jīng)濟的維護成本,它是CGI(CommonGatewayInterface)或Perlscripts的極佳的替代產(chǎn)品。缺點就是對于初學(xué)者來說,較復(fù)雜,也比較難。10、JCreator
JCreator是一個Java程序開發(fā)工具,也是一個Java集成開發(fā)環(huán)境(IDE)。無論你是要開發(fā)Java應(yīng)用程序或者網(wǎng)頁上的Applet元件都難不倒它。在功能上與Sun公司所公布的JDK等文字模式開發(fā)工具相較之下來得容易,還允許使用者自訂義操作窗口界面及無限Undo/Redo等功能。JCreator為用戶提供了相當(dāng)強大的功能,例如項目管理功能,項目模板功能,可個性化設(shè)置語法高亮屬性、行數(shù)、類瀏覽器、標(biāo)簽文檔、多功能編繹器,向?qū)Чδ芤约巴耆勺远x的用戶界面。通過JCreator,我們不用激活主文檔而直接編繹或運行我們的JAVA程序。JCreator能自動找到包含主函數(shù)的文件或包含Applet的Html文件,然后它會運行適當(dāng)?shù)墓ぞ?。在JCreator中,我們可以通過一個批處理同時編繹多個項目。JCreator的設(shè)計接近Windows界面風(fēng)格,用戶對它的界面比較熟悉。其最大特點是與我們機器中所裝的JDK完美結(jié)合,是其它任何一款I(lǐng)DE所不能比擬的。它是一種初學(xué)者很容易上手的java開發(fā)工具,缺點是只能進行簡單的程序開發(fā),不能進行企業(yè)J2EE的開發(fā)應(yīng)用。
11、MicrosoftVJ++
VisualJ++是Microsoft公司推出的可視化的Java語言集成開發(fā)環(huán)境(IDE),為Java編程人員提供了一個新的開發(fā)環(huán)境,是一個相當(dāng)出色的開發(fā)工具。無論集成性、編譯速度、調(diào)試功能、還是易學(xué)易用性,都體現(xiàn)了Microsoft的一慣風(fēng)格。VisualJ++具有
下面的特點:
1)VisualJ++把Java虛擬機(JVM)作為獨立的操作系統(tǒng)組件放入Windows,使之從瀏覽器中獨立出來。
2)Microsoft的應(yīng)用基本類庫(AFC,ApplicationFoundationClassLibrary)對SUN公司的JDK作了擴展,使應(yīng)用基本類庫更加適合在Windows下使用。
3)VisualJ++的調(diào)試器支持動態(tài)調(diào)試,包括單步執(zhí)行、設(shè)置斷點、觀察變量數(shù)值等。
4)VisualJ++提供了一些程序向?qū)?Wizards)和生成器(Builders),它們可以方便地幫助用戶快速地生成Java程序,幫助你在自己的工程中創(chuàng)建和修改文件。
5)VisualJ++界面友好,其代碼編輯器具有智能感知、聯(lián)機編譯等功能,使程序編寫十分方便。VisualJ++中建立了Java的WFC,這一新的應(yīng)用程序框架能夠直接訪問Windows應(yīng)用程序接口(API),使你能夠用Java語言編寫完全意義上的Windows應(yīng)用程序。
6)VisualJ++中表單設(shè)計器的快速應(yīng)用開發(fā)特性使用WFC創(chuàng)建基于表單的應(yīng)用程序變得輕松、簡單。通過WFC可以方便地使用ActiveX數(shù)據(jù)對象(ADO,ActiveXDataObjects)來檢索數(shù)據(jù)和執(zhí)行簡單數(shù)據(jù)的綁定。通過在表單設(shè)計器中使用ActiveX數(shù)據(jù)對象,可以快速地在表單中訪問和顯示數(shù)據(jù)。VisualJ++能結(jié)合微軟的一貫的編程風(fēng)格,很方便進行Java的應(yīng)用開發(fā),但它的移植性較差,不是純的Java開發(fā)環(huán)境。
12、Eclipse
Eclipse是一種可擴展的開放源代碼IDE。2001年11月,IBM公司捐出價值4,000萬美元的源代碼組建了Eclipse聯(lián)盟,并由該聯(lián)盟負(fù)責(zé)這種工具的后續(xù)開發(fā)。集成開發(fā)環(huán)境(IDE)經(jīng)常將其應(yīng)用范圍限定在“開發(fā)、構(gòu)建和調(diào)試”的周期之中。為了幫助集成開發(fā)環(huán)境(IDE)克服目前的局限性,業(yè)界廠商合作創(chuàng)建了Eclipse平臺。Eclipse允許在同一IDE中集成來自不同供應(yīng)商的工具,并實現(xiàn)了工具之間的互操作性,從而顯著改變了項目工作流程,使開發(fā)者可以專注在實際的嵌入式目標(biāo)上。Eclipse框架的這種靈活性來源于其擴展點。它們是在XML中定義的已知接口,并充當(dāng)插件的耦合點。擴展點的范圍包括從用在常規(guī)表述過濾器中的簡單字符串,到一個Java類的描述。任何Eclipse插件定義的擴展點都能夠被其它插件使用,反之,任何Eclipse插件也可以遵從其它插件定義的擴展點。除了解由擴展點定義的接口外,插件不知道它們通過擴展點提供的服務(wù)將如何被使用。利用Eclipse,我們可以將高級設(shè)計(也許是采用UML)與低級開發(fā)工具(如應(yīng)用調(diào)試器等)結(jié)合在一起。如果這些互相補充的獨立工具采用Eclipse擴展點彼此連接,那么當(dāng)我們用調(diào)試器逐一檢查應(yīng)用時,UML對話框可以突出顯示我們正在關(guān)注的器件。事實上,由于Eclipse并不了解開發(fā)語言,所以無論Java語言調(diào)試器、C/C++調(diào)試器還是匯編調(diào)試器都是有效的,并可以在相同的框架內(nèi)同時瞄準(zhǔn)不同的進程或節(jié)點。Eclipse的最大特點是它能接受由Java開發(fā)者自己編寫的開放源代碼插件,這類似于微軟公司的VisualStudio和Sun微系統(tǒng)公司的NetBeans平臺。Eclipse為工具開發(fā)商提供了更好的靈活性,使他們能更好地控制自己的軟件技術(shù)。Eclipse聯(lián)盟已經(jīng)宣布將在2004年中期發(fā)布其3.0版軟件。這是一款非常受歡迎的java開發(fā)工具,這國內(nèi)的用戶越來越多,實際上實用它java開發(fā)人員是最多的。缺點就是較復(fù)雜,對初學(xué)者來說,理解起來比較困難。
13、Ant
AnotherNeatTool(Ant)是一種基于Java的build工具。理論上來說,它有些類似于(Unix)C中的make,但沒有make的缺陷。因為Ant的原作者在多種(硬件)平臺上開發(fā)軟件時,無法忍受這些工具的限制和不便。類似于make的工具本質(zhì)上是基于shell(語言)的:他們計算依賴關(guān)系,然后執(zhí)行命令(這些命令與你在命令行敲的命令沒太大區(qū)別)。這就意味著你可以很容易地通過使用OS特有的或編寫新的(命令)程序擴展該工具;然而,這也意味著你將自己限制在了特定的OS,或特定的OS類型上,如Unix。Ant就不同了。與基于shell命令的擴展模式不同,Ant用Java的類來擴展。(用戶)不必編寫shell命令,配置文件是基于XML的,通過調(diào)用target樹,就可執(zhí)行各種task。每個task由實現(xiàn)了一個實現(xiàn)了特定Task接口的對象來運行。Ant支持一些可選task,一個可選task一般需要額外的庫才能工作??蛇xtask與Ant的內(nèi)置task分開,單獨打包。這個可選包可以從你下載Ant的同一個地方下載。ANT本身就是這樣一個流程腳本引擎,用于自動化調(diào)用程序完成項目的編譯,打包,測試等。除了基于JAVA是平臺無關(guān)的外,腳本的格式是基于XML的,比make腳本來說還要好維護一些。Ant是Apache提供給Java開發(fā)人員的構(gòu)建工具,它可以在WindowsOS和UnixOS下運行,它不僅開放源碼并且還是一個非常好用的工具。Ant是ApacheJakarta中一個很好用的Java開發(fā)工具,Ant配置文件采用XML文檔編寫,所以Java程序員對其語法相當(dāng)熟悉,Ant是專用于Java項目平臺,能夠用純Java來開發(fā),它能夠運行于Java安裝的平臺,即體現(xiàn)了它的跨平臺功能。它的缺點顯示執(zhí)行結(jié)果只能是DOS字符界面,不能進行復(fù)雜的java程序開發(fā)。
14、IntelliJ
IntellijIDEA是一款綜合的Java編程環(huán)境,被許多開發(fā)人員和行業(yè)專家譽為市場上最好的IDE。它提供了一系列最實用的的工具組合:智能編碼輔助和自動控制,支持J2EE,Ant,JUnit和CVS集成,非平行的編碼檢查和創(chuàng)新的GUI設(shè)計器。IDEA把Java開發(fā)人員從一些耗時的常規(guī)工作中解放出來,顯著地提高了開發(fā)效率。具有運行更快速,生成更好的代碼;持續(xù)的重新設(shè)計和日常編碼變得更加簡易,與其它工具的完美集成;很高的性價比等特點。在4.0版本中支持Generics,BEAWebLogic集成,改良的CVS集成以及GUI設(shè)計器。
IntelliJIDEA能盡可能地促進程序員的編程速度。它包括了很多輔助的功能,并且與Java結(jié)合得相當(dāng)好。不同的工具窗口圍繞在主編程窗口周圍,當(dāng)鼠標(biāo)點到時即可打開,無用時也可輕松關(guān)閉,使用戶得到了最大化的有效屏幕范圍。以技術(shù)為導(dǎo)向的IDEA集成了調(diào)試器,支持本地和遠程的調(diào)試,即使我們需要修改一些設(shè)置上的東西使我們的工作順利進展。另外,它還提供了通常的監(jiān)視,分步調(diào)試以及手動設(shè)置斷點功能,在這種斷點模式下,我們可以自動地在斷點之外設(shè)置現(xiàn)場訪問,甚至可以瀏覽不同的變量的值。IDE支持多重的JVM設(shè)置,幾個編譯程序和Ant建造系統(tǒng),并且,它使得設(shè)置多重的自定義的類途徑變得簡單。IntelliJIdea是一個相對較新的JavaIDE。它是Java開發(fā)環(huán)境中最為有用的一個。高度優(yōu)化的IntelleJIdea使普通任務(wù)變得相當(dāng)容易,Idea支持很多整合功能,更重要的使它們設(shè)計的好容易使用。Idea支持XML中的代碼實現(xiàn),Idea同時還會校正XML,Idea支持JSP的結(jié)構(gòu)。作用于普通Java代碼的眾多功能同樣適用于JSP(比如整合功能),同時支持JSP調(diào)試;支持EJB,盡管它不包括對個別應(yīng)用服務(wù)器的特殊支持。Idea支持Ant建立工具,不僅是運行目標(biāo)它還支持編譯與運行程序前后運行目標(biāo),另外也支持綁定鍵盤快捷鍵。在編輯一個Ant建立XML文件時,Idea還對組成Ant工程的XML部分提供支持。IntelliJIDEA被稱為是最好的JAVAIDE開發(fā)平臺,這套軟件就是以其聰明的即時分析和方便的refactoring功能深獲大家所喜愛。缺點是較復(fù)雜,對初學(xué)者來說,理解起來比較困難。
現(xiàn)在常用的Java項目開發(fā)環(huán)境有:JBuilder、VisualAgeforJava、ForteforJava,VisualCafe、Eclipse、NetBeansIDE、JCreator+J2SDK、jdk+記事本、EditPlus+J2SDK等等。一般開發(fā)J2EE項目時都需要安裝各公司的應(yīng)用服務(wù)器(中間件)和相應(yīng)的開發(fā)工具,在使用這些開發(fā)工具之前,我們最好能熟知這些軟件的優(yōu)點和缺點,以便根據(jù)實際情況選擇應(yīng)用。編程工具只是工具,為了方便人們工作而開發(fā)的,各有特點,因此,選工具主要的依據(jù)自己將要從事的領(lǐng)域是什么,而不是盲目的認(rèn)為那種工具好,那種工具不好。最后希望大家都能找到自己合適的java開發(fā)工具
本文首先介紹了靜態(tài)代碼分析的基本概念及主要技術(shù),隨后分別介紹了現(xiàn)有 4 種主流 Java 靜態(tài)代碼分析工具 (Checkstyle,F(xiàn)indBugs,PMD,Jtest),最后從功能、特性等方面對它們進行分析和比較,希望能夠幫助 Java 軟件開發(fā)人員了解靜態(tài)代碼分析工具,并選擇合適的工具應(yīng)用到軟件開發(fā)中。
引言
在 Java 軟件開發(fā)過程中,開發(fā)團隊往往要花費大量的時間和精力發(fā)現(xiàn)并修改代碼缺陷。Java 靜態(tài)代碼分析(static code analysis)工具能夠在代碼構(gòu)建過程中幫助開發(fā)人員快速、有效的定位代碼缺陷并及時糾正這些問題,從而極大地提高軟件可靠性并節(jié)省軟件開發(fā)和測試成 本。目前市場上的 Java 靜態(tài)代碼分析工具種類繁多且各有千秋,因此本文將分別介紹現(xiàn)有 4 種主流 Java 靜態(tài)代碼分析工具 (Checkstyle,F(xiàn)indBugs,PMD,Jtest),并從功能、特性等方面對它們進行分析和比較,希望能夠幫助 Java 軟件開發(fā)人員了解靜態(tài)代碼分析工具,并選擇合適的工具應(yīng)用到軟件開發(fā)中。
靜態(tài)代碼分析工具簡介
什么是靜態(tài)代碼分析
靜態(tài)代碼分析是指無需運行被測代碼,僅通過分析或檢查源程序的語法、結(jié)構(gòu)、過程、接口等來檢查程序的正確性,找出代碼隱藏的錯誤和缺陷,如參數(shù)不匹配,有歧義的嵌套語句,錯誤的遞歸,非法計算,可能出現(xiàn)的空指針引用等等。
在軟件開發(fā)過程中,靜態(tài)代碼分析往往先于動態(tài)測試之前進行,同時也可以作為制定動態(tài)測試用例的參考。統(tǒng)計證明,在整個軟件開發(fā)生命周期中,30% 至 70% 的代碼邏輯設(shè)計和編碼缺陷是可以通過靜態(tài)代碼分析來發(fā)現(xiàn)和修復(fù)的。
但是,由于靜態(tài)代碼分析往往要求大量的時間消耗和相關(guān)知識的積累,因此對于軟件開發(fā)團隊來說,使用靜態(tài)代碼分析工具自動化執(zhí)行代碼檢查和分析,能夠極大地提高軟件可靠性并節(jié)省軟件開發(fā)和測試成本。
靜態(tài)代碼分析工具的優(yōu)勢
1. 幫助程序開發(fā)人員自動執(zhí)行靜態(tài)代碼分析,快速定位代碼隱藏錯誤和缺陷。
2. 幫助代碼設(shè)計人員更專注于分析和解決代碼設(shè)計缺陷。
3. 顯著減少在代碼逐行檢查上花費的時間,提高軟件可靠性并節(jié)省軟件開發(fā)和測試成本。
Java 靜態(tài)代碼分析理論基礎(chǔ)和主要技術(shù)
缺陷模式匹配:缺陷模式匹配事先從代碼分析經(jīng)驗中收集足夠多的共性缺陷模式,將待分析代碼與已有的共性缺陷模式進行模式匹配,從而完成軟件的安全分析。這種方式的優(yōu)點是簡單方便,但是要求內(nèi)置足夠多缺陷模式,且容易產(chǎn)生誤報。
類型推斷:類型推斷技術(shù)是指通過對代碼中運算對象類型進行推理,從而保證代碼中每條語句都針對正確的類型執(zhí)行。這種技術(shù)首先將預(yù)定義一套類型機制,包括類 型等價、類型包含等推理規(guī)則,而后基于這一規(guī)則進行推理計算。類型推斷可以檢查代碼中的類型錯誤,簡單,高效,適合代碼缺陷的快速檢測。
模型檢查:模型檢驗建立于有限狀態(tài)自動機的概念基礎(chǔ)之上,這一理論將被分析代碼抽象為一個自動機系統(tǒng),并且假設(shè)該系統(tǒng)是有限狀態(tài)的、或者是可以通過抽象歸 結(jié)為有限狀態(tài)。模型檢驗過程中,首先將被分析代碼中的每條語句產(chǎn)生的影響抽象為一個有限狀態(tài)自動機的一個狀態(tài),而后通過分析有限狀態(tài)機從而達到代碼分析的 目的。模型檢驗主要適合檢驗程序并發(fā)等時序特性,但是對于數(shù)據(jù)值域數(shù)據(jù)類型等方面作用較弱。
數(shù)據(jù)流分析:數(shù)據(jù)流分析也是一種軟件驗證技術(shù),這種技術(shù)通過收集代碼中引用到的變量信息,從而分析變量在程序中的賦值、引用以及傳遞等情況。對數(shù)據(jù)流進行 分析可以確定變量的定義以及在代碼中被引用的情況,同時還能夠檢查代碼數(shù)據(jù)流異常,如引用在前賦值在后、只賦值無引用等。數(shù)據(jù)流分析主要適合檢驗程序中的 數(shù)據(jù)域特性。
現(xiàn)有主流 Java 靜態(tài)分析工具
Checkstyle
Checkstyle 是 SourceForge 的開源項目,通過檢查對代碼編碼格式,命名約定,Javadoc,類設(shè)計等方面進行代碼規(guī)范和風(fēng)格的檢查,從而有效約束開發(fā)人員更好地遵循代碼編寫規(guī)范。
Checkstyle 提供了支持大多數(shù)常見 IDE 的插件,文本主要使用 Eclipse 中的 Checkstyle 插件。如下圖 1 所示,Checkstyle 對代碼進行編碼風(fēng)格檢查,并將檢查結(jié)果顯示在 Problems 視圖中。圖中,代碼編輯器中每個放大鏡圖標(biāo)表示一個 Checkstyle 找到的代碼缺陷。開發(fā)人員可通過在 Problems 視圖中查看錯誤或警告詳細信息。
圖 1. 使用 Checkstyle 進行編碼風(fēng)格檢查
此外,Checkstyle 支持用戶根據(jù)需求自定義代碼檢查規(guī)范,在下圖 2 中的配置面板中,用戶可以在已有檢查規(guī)范如命名約定,Javadoc,塊,類設(shè)計等方面的基礎(chǔ)上添加或刪除自定義檢查規(guī)范。
圖 2. 使用 Checkstyle 添加自定義代碼檢查規(guī)范
FindBugs
FindBugs 是由馬里蘭大學(xué)提供的一款開源 Java 靜態(tài)代碼分析工具。FindBugs 通過檢查類文件或 JAR 文件,將字節(jié)碼與一組缺陷模式進行對比從而發(fā)現(xiàn)代碼缺陷,完成靜態(tài)代碼分析。FindBugs 既提供可視化 UI 界面,同時也可以作為 Eclipse 插件使用。文本將主要使用將 FindBugs 作為 Eclipse 插件。在安裝成功后會在 eclipse 中增加 FindBugs perspective,用戶可以對指定 Java 類或 JAR 文件運行 FindBugs,此時 FindBugs 會遍歷指定文件,進行靜態(tài)代碼分析,并將代碼分析結(jié)果顯示在 FindBugs perspective 的 bugs explorer 中,如下圖 3 所示:
圖 3. 使用 FindBugs 進行靜態(tài)代碼分析
圖中 Bug Explorer 中的灰色圖標(biāo)處為 Bug 類型,每種分類下紅色圖標(biāo)表示 bug 較為嚴(yán)重,黃色的圖標(biāo)表示 bug 為警告程度。Propreties 列出了 bug 的描述信息及修改方案。
此外,F(xiàn)indBugs 還為用戶提供定制 Bug Pattern 的功能。用戶可以根據(jù)需求自定義 FindBugs 的代碼檢查條件,如下圖 4 所示:
圖 4. 使用 FindBugs 添加自定義代碼檢查規(guī)范
PMD
PMD 是由 DARPA 在 SourceForge 上發(fā)布的開源 Java 代碼靜態(tài)分析工具。PMD 通過其內(nèi)置的編碼規(guī)則對 Java 代碼進行靜態(tài)檢查,主要包括對潛在的 bug,未使用的代碼,重復(fù)的代碼,循環(huán)體創(chuàng)建新對象等問題的檢驗。PMD 提供了和多種 Java IDE 的集成,例如 Eclipse,IDEA,NetBean 等。本文主要使用 PMD 以插件方式與 Eclipse 集成。如下圖 5 所示:在 Violations Overview 視圖中,按照代碼缺陷嚴(yán)重性集中顯示了 PMD 靜態(tài)代碼分析的結(jié)果。
圖 5. 使用 PMD 進行靜態(tài)代碼分析
PMD 同樣也支持開發(fā)人員對代碼檢查規(guī)范進行自定義配置。開發(fā)人員可以在下圖 6 中的面板中添加、刪除、導(dǎo)入、導(dǎo)出代碼檢查規(guī)范。
圖 6. 使用 PMD 添加自定義代碼檢查規(guī)范
Jtest
Jtest 是 Parasoft 公司推出的一款針對 Java 語言的自動化代碼優(yōu)化和測試工具,Jtest 的靜態(tài)代碼分析功能能夠按照其內(nèi)置的超過 800 條的 Java 編碼規(guī)范自動檢查并糾正這些隱蔽且難以修復(fù)的編碼錯誤。同時,還支持用戶自定義編碼規(guī)則,幫助用戶預(yù)防一些特殊用法的錯誤。Jtest 提供了基于 Eclipse 的插件安裝。Jtest 支持開發(fā)人員對 Java 代碼進行編碼規(guī)范檢查,并在 Jtask 窗口中集中顯示檢查結(jié)果,如下圖 7 所示:
圖 7. 使用 Jtest 進行靜態(tài)代碼分析
同時,Jtest 還提供了對用戶定制代碼檢查配置甚至自定義編碼規(guī)則的支持,這一功能使得開發(fā)人員可以基于不同場景定制所需要的編碼規(guī)范,如圖 8 所示:
圖 8. 使用 Jtest 添加自定義代碼檢查規(guī)范
Java 靜態(tài)分析工具對比
本章節(jié)將從以下幾個方面對上述 Java 靜態(tài)分析工具進行比較:
應(yīng)用技術(shù)及分析對象
下表 1 列出了不同工具的分析對象及應(yīng)用技術(shù)對比:
表 1. 不同工具的分析對象及應(yīng)用技術(shù)對比
Java 靜態(tài)分析工具
分析對象
應(yīng)用技術(shù)
Checkstyle ? ?Java 源文件 ? ?缺陷模式匹配 ?
FindBugs ? ?字節(jié)碼 ? ?缺陷模式匹配;數(shù)據(jù)流分析 ?
PMD ? ?Java 源代碼 ? ?缺陷模式匹配 ?
Jtest ? ?Java 源代碼 ? ?缺陷模式匹配;數(shù)據(jù)流分析 ?
內(nèi)置編程規(guī)范
Checkstyle:
Javadoc 注釋:檢查類及方法的 Javadoc 注釋
命名約定:檢查命名是否符合命名規(guī)范
標(biāo)題:檢查文件是否以某些行開頭
Import 語句:檢查 Import 語句是否符合定義規(guī)范
代碼塊大小,即檢查類、方法等代碼塊的行數(shù)
空白:檢查空白符,如 tab,回車符等
修飾符:修飾符號的檢查,如修飾符的定義順序
塊:檢查是否有空塊或無效塊
代碼問題:檢查重復(fù)代碼,條件判斷,魔數(shù)等問題
類設(shè)計:檢查類的定義是否符合規(guī)范,如構(gòu)造函數(shù)的定義等問題
FindBugs:
Bad practice 壞的實踐:常見代碼錯誤,用于靜態(tài)代碼檢查時進行缺陷模式匹配
Correctness 可能導(dǎo)致錯誤的代碼,如空指針引用等
國際化相關(guān)問題:如錯誤的字符串轉(zhuǎn)換
可能受到的惡意攻擊,如訪問權(quán)限修飾符的定義等
多線程的正確性:如多線程編程時常見的同步,線程調(diào)度問題。
運行時性能問題:如由變量定義,方法調(diào)用導(dǎo)致的代碼低效問題。
PMD:
可能的 Bugs:檢查潛在代碼錯誤,如空 try/catch/finally/switch 語句
未使用代碼(Dead code):檢查未使用的變量,參數(shù),方法
復(fù)雜的表達式:檢查不必要的 if 語句,可被 while 替代的 for 循環(huán)
重復(fù)的代碼:檢查重復(fù)的代碼
循環(huán)體創(chuàng)建新對象:檢查在循環(huán)體內(nèi)實例化新對象
資源關(guān)閉:檢查 Connect,Result,Statement 等資源使用之后是否被關(guān)閉掉
Jtest
可能的錯誤:如內(nèi)存破壞、內(nèi)存泄露、指針錯誤、庫錯誤、邏輯錯誤和算法錯誤等
未使用代碼:檢查未使用的變量,參數(shù),方法
初始化錯誤:內(nèi)存分配錯誤、變量初始化錯誤、變量定義沖突
命名約定:檢查命名是否符合命名規(guī)范
Javadoc 注釋:檢查類及方法的 Javadoc 注釋
線程和同步:檢驗多線程編程時常見的同步,線程調(diào)度問題
國際化問題:
垃圾回收:檢查變量及 JDBC 資源是否存在內(nèi)存泄露隱患
錯誤檢查能力
為比較上述 Java 靜態(tài)分析工具的代碼缺陷檢測能力,本文將使用一段示例代碼進行試驗,示例代碼中將涵蓋我們開發(fā)中的幾類常見錯誤,如引用操作、對象操作、表達式復(fù)雜化、數(shù) 組使用、未使用變量或代碼段、資源回收、方法調(diào)用及代碼設(shè)計幾個方面。最后本文將分別記錄在默認(rèn)檢查規(guī)范設(shè)置下,不同工具對該示例代碼的分析結(jié)果。以下為 示例代碼 Test.java。其中,代碼的注釋部分列舉了代碼中可能存在的缺陷。
清單 1. Test.java 示例代碼
package Test;import java.io.*;public class Test {/** ? ? * Write the bytes from input stream to output stream. ? ? * The input stream and output stream are not closed. ? ? * @param is ? ? * @param os ? ? * @throws IOException ? ? */public boolean copy(InputStream is, OutputStream os)throws IOException {intcount = 0;//缺少空指針判斷byte[] buffer =new byte[1024];while((count = is.read(buffer)) = 0) {os.write(buffer,0, count);}//未關(guān)閉I/O流returntrue;}/** ? ? * ? ? * @param a ? ? * @param b ? ? * @param ending ? ? * @return copy the elements from a to b, and stop when meet element ending ? ? */publicvoid copy(String[] a, String[] b, String ending){intindex;String temp =null;//空指針錯誤System.out.println(temp.length());//未使用變量intlength=a.length;for(index=0; indexa.length; index++){//多余的if語句if(true){//對象比較 應(yīng)使用equalsif(temp==ending){break;}//缺少 數(shù)組下標(biāo)越界檢查b[index]=temp;}}}/**? ? ?*? ? ?* @param file? ? ?* @return file contents as stri if file does not exist? ? ?*/public void? readFile(File file) {InputStream is =null;OutputStream os =null;try{is =new BufferedInputStream(newFileInputStream(file));os =new ByteArrayOutputStream();//未使用方法返回值copy(is,os);is.close();os.close();}catch (IOException e) {//可能造成I/O流未關(guān)閉e.printStackTrace();}finally{//空的try/catch/finally塊}}}
通過以上測試代碼,我們對已有 Java 靜態(tài)代碼分析工具的檢驗結(jié)果做了如下比較,如下表 2 所示。
表 2. Java 靜態(tài)代碼分析工具對比
代碼缺陷分類
示例
Checkstyle
FindBugs
PMD
Jtest
引用操作 ? ?空指針引用 ? ?√ ? ?√ ? ?√ ? ?√ ?
對象操作 ? ?對象比較(使用 == 而不是 equals) ? ?? ? ?√ ? ?√ ? ?√ ?
表達式復(fù)雜化 ? ?多余的 if 語句 ? ?? ? ?? ? ?√ ? ?? ?
數(shù)組使用 ? ?數(shù)組下標(biāo)越界 ? ?? ? ?? ? ?? ? ?√ ?
未使用變量或代碼段 ? ?未使用變量 ? ?? ? ?√ ? ?√ ? ?√ ?
資源回收 ? ?I/O 未關(guān)閉 ? ?? ? ?√ ? ?? ? ?√ ?
方法調(diào)用 ? ?未使用方法返回值 ? ?? ? ?√ ? ?? ? ?? ?
代碼設(shè)計 ? ?空的 try/catch/finally 塊 ? ?? ? ?? ? ?√ ? ?? ?
由表中可以看出幾種工具對于代碼檢查各有側(cè)重。其中,Checkstyle 更偏重于代碼編寫格式,及是否符合編碼規(guī)范的檢驗,對代碼 bug 的發(fā)現(xiàn)功能較弱;而 FindBugs,PMD,Jtest 著重于發(fā)現(xiàn)代碼缺陷。在對代碼缺陷檢查中,這三種工具在針對的代碼缺陷類別也各有不同,且類別之間有重疊。
總結(jié)
本文分別從功能、特性和內(nèi)置編程規(guī)范等方面詳細介紹了包括 Checkstyle,F(xiàn)indBugs,PMD,Jtest 在內(nèi)的四種主流 Java 靜態(tài)代碼分析工具,并通過一段 Java 代碼示例對這四種工具的代碼分析能力進行比較。由于這四種工具內(nèi)置編程規(guī)范各有不同,因此它們對不同種類的代碼問題的發(fā)現(xiàn)能力也有所不同。其中 Checkstyle 更加偏重于代碼編寫格式檢查,而 FindBugs,PMD,Jtest 著重于發(fā)現(xiàn)代碼缺陷。最后,希望本文能夠幫助 Java 軟件開發(fā)和測試人員進一步了解以上四種主流 Java 靜態(tài)分析工具,并幫助他們根據(jù)需求選擇合適的工具。