Java性能優化的五種方式

Java性能優化的五種方式算法

,JAVA性能優化之設計優化 
設計優化處於性能優化手段的上層。它每每需要在軟件開發以前進行。在軟件開發以前,系統架構師應該就評估系統可能存在的各類潛在問題和技術難點,並給出合理的設計方案,由於軟件設計和系統架構對軟件整體設計質量有決定性的影響。因此,設計調優對系統的性能影響也是最大的,假設說,代碼優化。JVM優化都是對系統微觀層次的的優化,那設計優化就是對系統的優化
設計優化的一大顯著特徵是:它可以規避某一個組件的性能問題,而是改良組件的實現;比方:組件A經過循環監控不斷的檢測時間E是否發生,其檢測行爲一定會佔用部分系統資源,所以,開發者必須檢測頻率和資源消耗上取得平衡,假設檢測頻率過低,儘管下降了資源消耗,但是系統實時反應性就會下降,假設進行代碼層的調優,就需要優化檢測方法的實現及要求得一個最爲恰當的檢測頻率.對於這個問題咱們就可以用設計模式中的觀察者模式 ,當事件E發生的時刻,由事件E通知組件A,從而觸發組件A的行爲.這樣的設計從根本上攻克了存在性能隱患的循環監控,從根本上攻克了這一問題
進行設計優化時,設計人員和必須熟悉常用的設計方法,設計模式,以及主要的性能組件和常用的優化思想,並將其有機地集成在軟件系統中
注意:一個良好的系統設計可以規避很是多潛在在的性能問題.所以,儘量多花些時間在系統設計上,是建立高性能程序的關鍵 
,JAVA性能優化之代碼優化 
代碼調優是在軟件開發中,或者是軟件開發完畢後,軟件維護過程當中進行的程序代碼的改進和優化.代碼優化涉及諸多編碼技巧,需要開發者熟悉相關的語言API ,並在適合的場景中正確的使用相關API或類庫.同一時候,對算法,數據結構的靈活使用,也是代碼優化的一個重要內容
儘管代碼優化時從微觀上對性能進行調整,但是一個的實現和一個的實現對系統的影響也是很是大的.比方,相同做爲List的實現,LinkedListArrayList在隨機訪問上的性能卻差了好幾個量級;比方相同是文件讀寫的實現,使用Stream方式和使用JAVA NIO的方式,其系能可能又會是還有一個數量級
所以,儘管與設計優化相比,筆者將代碼優化成爲在微觀層面上的優化,但它倒是對系統性能產生最直接影響的優化方法
,JVM優化 
由於JAVA軟件老是執行在JVM虛擬機之上。對JVM虛擬機進行優化也能必定程度上的提高JAVA程序的性能。JVM一般可以在軟件開發後期進行,如在開發完畢或者是軟件開發的某一里程碑階段。 
做爲JAVA軟件的執行平臺。JVM的各項參數將會直接影響JAVA程序的性能。數據庫

比方,JVM的堆大小,垃圾回收策略等等。 
要進行JVM層面的調優。需要開發者對JVM的執行原理和基本內存結構有必定的瞭解。如,堆內存的結構,GC的種類等。而後,根據引用程序的特色。設置合理的JVM啓動參數。編程


四。數據庫優化 
對絕大部分應用系統而言。數據庫是不可缺乏的一部分。JAVA程序可以使用JDBC的方式鏈接數據庫。對數據庫的調優可以分爲三個部分:設計模式

  • 在應用層對SQL語句進行優化;
  • 對數據庫進行優化。
  • 對數據庫軟件進行優化。

在應用層優化數據庫訪問。涉及大量的編程技巧。比方。當使用JDBC進行查詢的時候,對於大量擁有相同結構的SQL查詢,可以使用PerparedStatement取代Statement。以提升數據庫的查詢效率。在使用Select語句中,顯示指定要查詢的列名 ,避免使用
在對數據庫優化時,主要目的是創建一個具備良好表結構的數據庫。性能優化

比方,爲了提升多表級聯查詢的效率,可以合理地使用冗餘字段;對於大表,可以使用行的水平分割或者類似Oracle分區的技術;爲了提升數據的查詢的效率,可以創建有效水平分割或者類似Oracle分區表的技術;爲了提升數據庫查詢效率。在select語句中。顯示指定要查詢的列名,避免使用* 
在對數據庫進行優化時。主要目的是創建一個具備良好表結構的數據庫。比方,爲了提升多表級聯查詢效率,可以合理地使用冗餘字段。對於大表。可以使用行數據來水平分割,爲了提升數據庫的查詢效率,可以創建有效且事宜的索引 
五,JAVA性能優化之操做系統優化 
操做系統,調優的手段和參數可能有所不一樣,比方,在主流Unix系統中。共享內存段。信號量,共享內存最大值(shmmax)。共享內存最小值(shmmin)等都是可以進行優化的系統資源.此外,如最大文件句柄數,虛擬內存大小,磁盤的塊大小等參數均可能對軟件的性能產生影響.配置虛擬內存界面數據結構

相關文章
相關標籤/搜索