使用工具Source Monitor測量您Java程式碼的環複雜度
程式碼的環複雜度(Cyclomatic complexity,有時也翻譯成圈複雜度)是一種程式碼複雜度的衡量標準,在1976年由Thomas J. McCabe, Sr. 提出。
來看看計算公式。
程式碼環複雜度 = E − N + 2
E = 程式控制流圖中邊的個數
N = 程式控制流圖中點的個數
很容易得出這樣的結論:程式碼環複雜度越高,越容易出bug。
可以想象如果需要開發人員自己去把一段程式碼的控制流圖畫出來,然後去數圖中邊和點的個數,這種做法效率太低了也容易出錯。
好訊息是,有一款名為Source Monitor的免費軟體,能夠幫我們來度量Java程式碼的環複雜度。當然這款軟體也支援C++和C#。
為了說明如何使用這款軟體,我寫了一段簡單的Java程式碼。
package test;import java.util.ArrayList;public class monthTool {static ArrayList<String> monthCollection = new ArrayList<String>();public static void main(String[] args) { monthTool tool = new monthTool(); tool.printV1(1); tool.printV2(2); tool.printV1(0); tool.printV2(-1); tool.printV3(3); tool.printV3(13); }public monthTool(){ monthCollection.add("Invalid"); monthCollection.add("January"); monthCollection.add("Febrary"); monthCollection.add("March"); monthCollection.add("April"); monthCollection.add("May"); monthCollection.add("June"); monthCollection.add("July"); monthCollection.add("August"); monthCollection.add("September"); monthCollection.add("October"); monthCollection.add("November"); monthCollection.add("December"); }public void printV1(int month){ System.out.println("Month is: " + getMonthNameV1(month)); }public void printV2(int month){if( month >= 1 && month <= 12) System.out.println("Month is: " + getMonthNameV2(month));elseSystem.out.println("Please specify a valid month"); }public void printV3(int month) { System.out.println("Month is: " + getMonthNameV3(month)); }public String getMonthNameV2(int month){if( month == 1)return "January";else if( month == 2)return "Febrary";else if( month == 3)return "March";else if( month == 4)return "April";else if( month == 5)return "May";else if( month == 6)return "June";else if( month == 7)return "July";else if( month == 8)return "August";else if( month == 9)return "September";else if( month == 10)return "October";else if( month == 11)return "November";else if( month == 12)return "December";elsereturn "Invalid"; }public String getMonthNameV1(int month){switch (month){case 1:return "January";case 2:return "Febrary";case 3:return "March";case 4:return "April";case 5:return "May";case 6:return "June";case 7:return "July";case 8:return "August";case 9:return "September";case 10:return "October";case 11:return "November";case 12:return "December";default:return "Invalid"; } }public String getMonthNameV3(int month){try {return monthCollection.get(month); }catch (java.lang.IndexOutOfBoundsException e){return "Invalid"; } } }
其中我用了三種不同的方式實現了同一個邏輯,將一個代表月份的整數轉成了月份名稱。
下面是Source Monitor的具體用法。
1. 建立一個新的專案:
這裡能看到所有Source Monitor支援的程式語言。
2. 指定您本地的Java專案檔案地址:
3. 指定您的Java專案資料夾內,您希望SourceMonitor計算哪些Java檔案的環複雜度。
4. 點OK,就可以開始掃描啦。
很快Source Monitor就將我們指定的Java檔案的環複雜度計算完畢。點選選單“Display Method Metrics”來檢視結果:
從環複雜度掃描結果能看出,明顯第三種從月份名稱集合裡通過ArrayList自帶的get方法取得月份名稱是最優的解法——環複雜度僅為2。
也可以通過圖表的方式更直觀得看到方法的環複雜度比較:
X軸的值代表每個方法的環複雜度,Y軸代表這些環複雜度的不同值出現的次數。
比如下圖的意思是,環複雜度為1的方法(X軸刻度為1的節點)共有4個(Y軸刻度為4),環複雜度為2的方法(X軸刻度為2的節點)有1個(Y軸刻度為1)。以此類推。
要獲取更多Jerry的原創技術文章,請關注公眾號"汪子熙"或者掃描下面二維碼:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2199506/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 如何計算並測量ABAP及Java程式碼的環複雜度Cyclomatic complexityJava複雜度
- 降低程式碼的圈複雜度——複雜程式碼的解決之道複雜度
- 淺析程式碼圈複雜度及認知複雜度複雜度
- 前端程式碼質量-圈複雜度原理和實踐前端複雜度
- 圈複雜度那些事兒-前端程式碼質量系列文章(二)複雜度前端
- DDD之理解複雜度、尊重複雜度、掌控複雜度複雜度
- 如何減小ABAP業務程式碼的複雜度複雜度
- 降低程式碼圈複雜度最佳化技巧複雜度
- 複雜度分析的套路及常見的複雜度複雜度
- 時間複雜度跟空間複雜度時間複雜度
- 時間複雜度與空間複雜度時間複雜度
- 時間複雜度和空間複雜度時間複雜度
- 簡單程式的時間複雜度分析時間複雜度
- dotnet 程式碼最佳化 聊聊邏輯圈複雜度複雜度
- 複雜度分析複雜度
- Java程式碼工具EasyCode使用Java
- Linux 如何設定密碼複雜度?Linux密碼複雜度
- 時間複雜度O(n)和空間複雜度時間複雜度
- 幽默:過度使用Lambda的Java程式碼Java
- 重構指標之如何監控程式碼圈複雜度指標複雜度
- php程式碼檢測工具使用PHP
- 0 程式碼量雜談
- ArrayList的時間複雜度 – Java那些事兒專欄時間複雜度Java
- es的複雜查詢測試,使用jest的dsl工具寫查詢語句
- 時間複雜度 – Java那些事兒專欄時間複雜度Java
- 122 演算法的時間複雜度和空間複雜度詳解演算法時間複雜度
- 幹掉複雜的工具類,國產Java工具類庫 Hutool 很香!Java
- git管理複雜專案程式碼Git
- 使用htmlprettify美化您的HTML程式碼HTML
- Tessy—支援複雜場景測試的單元整合測試工具
- 使用 Source Generators 快速編寫 MVVM 程式碼MVVM
- source insight中使用astyle的程式碼的格式化AST
- 那些年忽略的知識:時間複雜度和空間複雜度詳解時間複雜度
- 時間複雜度怎麼算?如何計算時間複雜度?時間複雜度
- Javascript校驗密碼複雜度的正規表示式JavaScript密碼複雜度
- Profile設定高標準密碼複雜度的方法密碼複雜度
- 藍橋杯-數三角(ac程式碼時間複雜度分析)C程式時間複雜度
- 時間複雜度的計算時間複雜度