[Java] if-else pk switch,誰快?

[Java] if-else pk switch,誰快?

技術文章又來啦,當沒題材時,技術文章就是最好的工具人。

今天要介紹的是之前在公司 Code Review 探討過的一個問題,if-else 跟 switch 誰快?不囉唆,直接公佈答案:大部分情況 switch 快,但絕少部份 if 快。

switch 判斷的方式類似 HashMap,採用 Binary Tree 的方式,當有 8 個 case 時,最少需要判斷3 次才能找到要執行的區段,因為 2^3=8。這可能因為 Compiler 不同有不同的最佳方式,我用的是 JDK 1.4,推論是這樣。

但 if 就是從頭開始判斷,如果第一個條件就 match 到,那速度就超快的,即使後續有 n 個 if-else 都無所謂了。

所以結論就是如果已經知道非常大部分都會落在某一個選項,採用 if 的方式,把最常發生的選項放在 if 的第一個,保證速度最快。但如果每一個選項都有一定的機率會被判斷到,採用 switch 會是比較保險的選擇。

驗證的程式如下,第一個是 switch。

 1:   public static void caseSwitch(int a) {
 2:    long s = System.currentTimeMillis();
 3:    for (int i = 0; i < 100000000; i++) {
 4:     switch (a) {
 5:      case 3 :
 6:       break;
 7:      case 5 :
 8:       break;
 9:      case 7 :
10:       break;
11:      case 2 :
12:       break;
13:      case 6 :
14:       break;
15:      case 4 :
16:       break;
17:      case 1 :
18:       break;
19:      default :
20:       break;
21:     }
22:    }
23:    long e = System.currentTimeMillis();
24:    System.out.println("Switch Cost: " + (e - s));
25:   }

第二個是 if。

 1:   public static void caseIf(int a) {
 2:    long s = System.currentTimeMillis();
 3:    for (int i = 0; i < 100000000; i++) {
 4:     if (a == 3) {
 5:     } else if (a == 5) {
 6:     } else if (a == 7) {
 7:     } else if (a == 2) {
 8:     } else if (a == 6) {
 9:     } else if (a == 4) {
10:     } else if (a == 1) {
11:     }
12:    }
13:    long e = System.currentTimeMillis();
14:    System.out.println("If Cost: " + (e - s));
15:   }

當傳入的數值落在 if 跟 switch 的最後一個選項時,if 比較慢。

caseSwitch(1); // --> Switch Cost: 328
caseIf(1); // --> If Cost: 532

當傳入的數值落在 if 跟 switch 的第一個選項時,if 變得比較快了。

caseSwitch(3); // --> Switch Cost: 422
caseIf(3); // --> If Cost: 297

實際比較起來,執行一億次差不到半秒鐘,雖然說各有優勢,但優勢實在太小了,等有寫到十億次、一兆次的程式再來考慮就好,平常跑個幾千次的就隨便用了啦,差別實在太小了。

PS:有人會說那換成 char 會不會有所不一樣, 有空的人可以去測測看,我測試的結論是一樣。