java一直是開發(fā)界比較受歡迎的開發(fā)語言,對于開發(fā)者來說java在他們心中的地位是非常的高的。在這么多的開發(fā)語言中java一直可以處于不敗的地位是有它的道理的,java不管是在性能上還是包容上都比其他的語言要高,下面達內(nèi)科技的小編就來給大家講解下有哪些方法是可以讓java的性能調(diào)優(yōu)的?
Java性能調(diào)優(yōu)有哪些方式?
1、設(shè)計調(diào)優(yōu)
設(shè)計調(diào)優(yōu)處于Java性能調(diào)優(yōu)手段的上層,它往往須要在軟件開發(fā)之前進行。在軟件開發(fā)之前,系統(tǒng)架構(gòu)師應(yīng)該就評估系統(tǒng)可能存在的各種潛在問題和技術(shù)難點,并給出合理的設(shè)計方案,因為軟件設(shè)計和系統(tǒng)架構(gòu)對軟件總體設(shè)計質(zhì)量有決定性的影響。所以,設(shè)計調(diào)優(yōu)對系統(tǒng)的性能影響也是的,如果代碼調(diào)優(yōu)、JVM調(diào)優(yōu)都是對系統(tǒng)微觀層次的“量”的優(yōu)化,那設(shè)計調(diào)優(yōu)就是對系統(tǒng)”質(zhì)”的優(yōu)化.
設(shè)計調(diào)優(yōu)的一大顯著特征是:它能夠規(guī)避某一個組件的性能問題,而是改良組件的實現(xiàn);打個比方,組件A通過循環(huán)監(jiān)控不斷的檢測時間E是否發(fā)生,其檢測行為必定會占用部分系統(tǒng)資源。因此,開發(fā)者必須檢測頻率和資源消耗上取得平衡。假設(shè)檢測頻率太低,盡管降低了資源消耗,可是系統(tǒng)實時反應(yīng)性就會降低;假設(shè)進行代碼層的調(diào)優(yōu),就須要優(yōu)化檢測方法的實現(xiàn)及要求得一個為恰當(dāng)?shù)臋z測頻率。對于這個問題,我們就能夠用設(shè)計模式中的觀察者模式
,當(dāng)事件E發(fā)生的時刻,由事件E通知組件A,從而觸發(fā)組件A的行為。這樣的設(shè)計從根本上攻克了存在性能隱患的循環(huán)監(jiān)控,從根本上攻克了這一問題。進行設(shè)計調(diào)優(yōu)時,設(shè)計人員和必須熟悉經(jīng)常使用的設(shè)計方法,設(shè)計模式,以及主要的性能組件和經(jīng)常使用的優(yōu)化思想,并將其有機地集成在軟件系統(tǒng)中。
2、代碼調(diào)優(yōu)
代碼調(diào)優(yōu)是在軟件開發(fā)中,或者是軟件開發(fā)完畢后,軟件維護過程中進行的程序代碼的改進和優(yōu)化。代碼優(yōu)化涉及諸多編碼技巧,須要開發(fā)者熟悉相關(guān)的語言API
,并在適合的場景中正確的使用相關(guān)API或類庫。同一時候,對算法,數(shù)據(jù)結(jié)構(gòu)的靈活使用,也是代碼優(yōu)化的一個重要內(nèi)容。
盡管代碼優(yōu)化時,從微觀上對性能進行調(diào)整,可是一個”好”的實現(xiàn)和一個”壞”的實現(xiàn),對系統(tǒng)的影響也是非常大的。還是打個比方,相同作為List的實現(xiàn),linkedList和ArrayList在隨機訪問上的性能卻差了好幾個量級;比方相同是文件讀寫的實現(xiàn),使用Stream方式和使用JAVA
NIO的方式,其系能可能又會是還有一個數(shù)量級。因此,盡管與設(shè)計優(yōu)化相比,筆者將代碼優(yōu)化成為在微觀層面上的優(yōu)化,但它卻是對系統(tǒng)性能產(chǎn)生直接影響的優(yōu)化方法。
3、JVM調(diào)優(yōu)
因為JAVA軟件總是執(zhí)行在JVM虛擬機之上。對JVM虛擬機進行優(yōu)化,也能一定程度上的提升JAVA程序的性能。JVM通常能夠在軟件開發(fā)后期進行,如在開發(fā)完畢或者是軟件開發(fā)的某一里程碑階段。作為JAVA軟件的執(zhí)行平臺,JVM的各項參數(shù)將會直接影響JAVA程序的性能。舉個例子,JVM的堆大小,垃圾回收策略等等。要進行JVM層面的調(diào)優(yōu)。須要開發(fā)者對JVM的執(zhí)行原理和基本內(nèi)存結(jié)構(gòu)有一定的了解。如,堆內(nèi)存的結(jié)構(gòu),GC的種類等。然后,根據(jù)引用程序的特點,設(shè)置合理的JVM啟動參數(shù)。
4、數(shù)據(jù)庫調(diào)優(yōu)
對絕大部分應(yīng)用系統(tǒng)而言,數(shù)據(jù)庫是不可缺少的一部分,JAVA程序能夠使用JDBC的方式連接數(shù)據(jù)庫。對數(shù)據(jù)庫的調(diào)優(yōu)能夠分為三個部分:在應(yīng)用層對SQL語句進行優(yōu)化;對數(shù)據(jù)庫進行優(yōu)化。對數(shù)據(jù)庫軟件進行優(yōu)化。在應(yīng)用層優(yōu)化數(shù)據(jù)庫訪問。涉及大量的編程技巧。比方。當(dāng)使用JDBC進行查詢的時候,對于大量擁有相同結(jié)構(gòu)的SQL查詢,能夠使用PerparedStatement取代Statement。以提高數(shù)據(jù)庫的查詢效率。在使用Select語句中,顯示指定要查詢的列名
,避免使用*在對數(shù)據(jù)庫優(yōu)化時,主要目的是建立一個具有良好表結(jié)構(gòu)的數(shù)據(jù)庫。在對數(shù)據(jù)庫進行優(yōu)化時。主要目的是建立一個具有良好表結(jié)構(gòu)的數(shù)據(jù)庫。比如,為了提高多表級聯(lián)查詢效率,能夠合理地使用冗余字段。對于大表。能夠使用行數(shù)據(jù)來水平分割,為了提高數(shù)據(jù)庫的查詢效率,能夠建立有效且事宜的索引。
5、操作系統(tǒng)調(diào)優(yōu)
操作系統(tǒng),調(diào)優(yōu)的手段和參數(shù)可能有所不同。比如,在主流Unix系統(tǒng)中,共享內(nèi)存段。信號量,共享內(nèi)存值。共享內(nèi)存小值等都是能夠進行優(yōu)化的系統(tǒng)資源。此外,如文件句柄數(shù),虛擬內(nèi)存大小,磁盤的塊大小等參數(shù)都可能對軟件的性能產(chǎn)生影響,配置虛擬內(nèi)存界面。
以上就是達內(nèi)科技的小編給大家整理的關(guān)于有哪些方法可以讓java的性能調(diào)優(yōu)的方法了,如果說活你想要了解更多關(guān)于java的知識的話,那么達內(nèi)科技?xì)g迎大家來我們的java培訓(xùn)班進行實地考察,也可以點擊我們文章下面的獲取試聽資格按鈕來獲取我們的java技術(shù)課程試聽資格,在免費試聽中可以和我們的講師進行面對面的交流。