如何優化Java程式碼,在工作上有哪些實用技巧可用?
1.類別成員與方法的可見性最小化
範例:如果是一個private的方法,想刪除就刪除
如果一個 public
的service
方法,或是public的成員變量,刪除一下,不得思考很多。
2.使用位移操作替代乘除法
計算機是使用二進位表示的,位移操作會大大提高性能。
> 右移相當於除以2;
>>> 無符號右移相當於除以2,但它會忽略符號位,空位都以0 補齊。
a = val << 3; b = val >> 1;
3.盡量減少對變數的重複計算
我們知道對方法的呼叫是有消耗的,包括創建堆疊幀、調用方法時保護現場,恢復現場等。
//反例 for (int i = 0; i < list.size(); i++) { System.out.println("result"); } //正例 for (int i = 0, length = list.size(); i < length; i++) { System.out.println("result"); }
在list.size()
很大的時候,就減少了很多的消耗。
4.不要捕捉RuntimeException
RuntimeException 不應該透過 catch 語句去捕捉,而應該使用編碼手段進行規避。
如下面的程式碼,list 可能會出現陣列越界異常。
是否越界是可以透過程式碼提前判斷的,而不是等到發生異常時去捕捉。
事先判斷這種方式,程式碼會更優雅,效率也更高。
public String test1(List<String> list, int index) { try { return list.get(index); } catch (IndexOutOfBoundsException ex) { return null; } } //正例 public String test2(List<String> list, int index) { if (index >= list.size() || index < 0) { return null; } return list.get(index); }
5.使用局部變數可避免在堆上分配
由於堆資源是多執行緒共享的,是垃圾回收器工作的主要區域,過多的物件會造成GC 壓力,可以透過局部變數的方式,將變數在堆疊上分配。這種方式變數會隨著方法執行的完畢而銷毀,能夠減輕 GC 的壓力。
6.減少變數的作用範圍
注意變數的作用範圍,盡量減少物件的建立。
如下面的程式碼,變數 s 每次進入方法都會創建,可以將它移到 if 語句內部。
public void test(String str) { final int s = 100; if (!StringUtils.isEmpty(str)) { int result = s * s; } }
7.懶載入策略
盡量採用懶載入的策略,在需要的時候才建立
String str = "月伴飞鱼"; if (name == "公众号") { list.add(str); } if (name == "公众号") { String str = "月伴飞鱼"; list.add(str); }
8.存取靜態變數直接使用類別名稱
使用物件存取靜態變量,這種方式多了一步尋址操作,需要先找到變數對應的類,再找到類別對應的變數。
// 反例 int i = objectA.staticMethod(); // 正例 int i = ClassA.staticMethod();
9.字串拼接使用StringBuilder
字串拼接,使用 StringBuilder 或 StringBuffer,不要使用 號。
//反例 public class StringTest { @Test public void testStringPlus() { String str = "111"; str += "222"; str += "333"; System.out.println(str); } } //正例 public class TestMain { public static void main(String[] args) { StringBuilder sb = new StringBuilder("111"); sb.append("222"); sb.append(333); System.out.println(sb.toString()); } }
10.重寫物件的HashCode
重寫物件的HashCode,不要簡單地回傳固定值
有同學在開發重寫HashCode 和Equals 方法時,會把HashCode 的值回傳固定的0,而這樣做是不恰當的
當這些物件存入HashMap 時,效能就會非常低,因為HashMap 是透過HashCode 定位到Hash 槽,有衝突的時候,才會使用鍊錶或紅黑樹組織節點,固定地回傳0,相當於把Hash 位址功能無效了。
11.HashMap等集合初始化
HashMap等集合初始化的時候,指定初始值大小
這樣的物件有很多,例如ArrayList,StringBuilder 等,透過指定初始值大小可減少擴容造成的性能損耗。
初始值大小計算:
#12.循環內建立物件參考
循環內不要不斷建立物件參考
//反例 for (int i = 1; i <= size; i++) { Object obj = new Object(); } //正例 Object obj = null; for (int i = 0; i <= size; i++) { obj = new Object(); }
第一種會導致記憶體中有size個Object物件參考存在,size很大的話,就耗費記憶體了
13.遍歷Map 使用EntrySet 方法
使用EntrySet 方法,可以直接返回set 對象,直接拿來用即可;而使用KeySet 方法,得到的是key 的集合,需要再進行一次get 操作,多了一個操作步驟,所以更建議使用EntrySet 方式遍歷Map。
Set<Map.Entry<String, String>> entryseSet = nmap.entrySet(); for (Map.Entry<String, String> entry : entryseSet) { System.out.println(entry.getKey()+","+entry.getValue()); }
14.不要在多執行緒下使用同一個Random
Random 類別的seed 會在並發存取的情況下發生競爭,造成效能降低,建議在多執行緒環境下使用ThreadLocalRandom類。
public static void main(String[] args) { ThreadLocalRandom threadLocalRandom = ThreadLocalRandom.current(); Thread thread1 = new Thread(()->{ for (int i=0;i<10;i++){ System.out.println("Thread1:"+threadLocalRandom.nextInt(10)); } }); Thread thread2 = new Thread(()->{ for (int i=0;i<10;i++){ System.out.println("Thread2:"+threadLocalRandom.nextInt(10)); } }); thread1.start(); thread2.start(); }
15.自增推薦使用LongAddr
自增運算可以透過synchronized
和volatile
的組合來控制執行緒安全,或者也可以使用原子類別(例如AtomicLong)。
後者的速度比前者高一些,AtomicLong
使用CAS 進行比較替換,在線程多的情況下會造成過多無效自旋,可以使用LongAdder 替換AtomicLong 進行進一步的性能提升。
public class Test { public int longAdderTest(Blackhole blackhole) throws InterruptedException { LongAdder longAdder = new LongAdder(); for (int i = 0; i < 1024; i++) { longAdder.add(1); } return longAdder.intValue(); } }
16.程式中要少用反射
反射的功能很強大,但它是透過解析字節碼實現的,效能就不是很理想。
現實中有很多對反射的最佳化方法,例如把反射執行的過程(例如 Method)快取起來,使用複用來加快反射速度。
Java 7.0 之後,加入了新的套件java.lang.invoke
#,同時加入了新的JVM 字節碼指令invokedynamic,用來支援從JVM 層面,直接透過字串對目標方法進行呼叫。
以上是如何優化Java程式碼,在工作上有哪些實用技巧可用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

膠囊是一種三維幾何圖形,由一個圓柱體和兩端各一個半球體組成。膠囊的體積可以通過將圓柱體的體積和兩端半球體的體積相加來計算。本教程將討論如何使用不同的方法在Java中計算給定膠囊的體積。 膠囊體積公式 膠囊體積的公式如下: 膠囊體積 = 圓柱體體積 兩個半球體體積 其中, r: 半球體的半徑。 h: 圓柱體的高度(不包括半球體)。 例子 1 輸入 半徑 = 5 單位 高度 = 10 單位 輸出 體積 = 1570.8 立方單位 解釋 使用公式計算體積: 體積 = π × r2 × h (4

PHP和Python各有優勢,適合不同場景。 1.PHP適用於web開發,提供內置web服務器和豐富函數庫。 2.Python適合數據科學和機器學習,語法簡潔且有強大標準庫。選擇時應根據項目需求決定。

Java是熱門程式語言,適合初學者和經驗豐富的開發者學習。本教學從基礎概念出發,逐步深入解說進階主題。安裝Java開發工具包後,可透過建立簡單的「Hello,World!」程式來實踐程式設計。理解程式碼後,使用命令提示字元編譯並執行程序,控制台上將輸出「Hello,World!」。學習Java開啟了程式設計之旅,隨著掌握程度加深,可創建更複雜的應用程式。

PHP成為許多網站首選技術棧的原因包括其易用性、強大社區支持和廣泛應用。 1)易於學習和使用,適合初學者。 2)擁有龐大的開發者社區,資源豐富。 3)廣泛應用於WordPress、Drupal等平台。 4)與Web服務器緊密集成,簡化開發部署。
