成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何有效的解決代碼的圈復雜度

開發 前端
不過最后我們也看到了,實際上,只是刻板的使用圈復雜度的算法,去度量一個段代碼的清晰度,有時候也是不可取的,所以我們在重構系統的時候,可以通過圈復雜度的工具,進行復雜度的統計,然后對復雜度高的代碼,具體場景,具體分析。而不能一味的教條。

作者:京東零售 張學剛

背景介紹

不管小型公司還是大型互聯網公司,很多項目債臺高筑,新功能開發困難。其中一個很大的原因就是代碼復雜,可讀性差。Sonar開發團隊曾上綱上線的戲稱開發人員的7宗罪,其中很關鍵的一條就是“復雜度”。那復雜度有沒有一個明確的衡量標準,我們又如何去解決代碼的圈復雜度呢?今天我在這里和大家聊一下。

圈復雜度的計算方法

我們先來看一下圈復雜度與代碼質量以及測試和維護成本之間的一個關系。

我們可以看到當圈復雜度,在1-10之間的時候,代碼是清晰,結構化的。可測試性比較高,維護成本也比較低。隨著圈復雜度的升高,代碼的狀況開始惡化,當大于30的時候,代碼已經逐步變為不可讀,維護成本非常高。

點邊計算法

那圈復雜度是如何計算的呢,常用的第一種方法叫做點邊計算法,它圈復雜度的計算方式 V(G) = E ? N + 2,我們用下邊圖來解釋一下這個公式:

其中公式之中的E指的是控制流圖中邊的數量,N指的是控制流圖中的節點數量。這兩個圖形指的就是控制流圖。那我們可以計算一下,第一個控制流圖的圈復雜度是:4-4+2=2.

節點判定法

除此之外圈復雜度還有一種更為直觀的計算方法,因為圈復雜度實際上體現了“判定條件”的數量,所以圈復雜度實際上就是等于判定節點的數量再加上1。它的計算公式為:V (G) = P + 1 其中判定節點(P)指的是我們常用的分支語句。例如if語句、while語句、case語句等。

那如何來降低圈復雜度呢?

圈復雜度的常用解決方法

提煉函數

接下來我們重點介紹一些降低圈復雜的方法,我通過工作中常見的代碼,來表述一下,如何去降低復雜度,如果你有更好的方法,也歡迎留言跟我交流。在我們的工作中,做業務系統的時候,通過異步消息進行數據傳遞,是比較常用的一種方式,在我們監聽到對端系統的消息的時候,一般會做這幾件事情。判斷消息是否為空-->轉換消息為數據傳輸對象DTO-->進一步的判斷對象的數據是否合法-->進行業務邏輯的處理。這幾個典型的步驟,很多童鞋可能用左邊圖的方式進行處理。這個時候,如果每一個步驟的方法比較復雜的時候,這個總的方法會非常復雜,這個時候,我們可以通過提煉方法的方式,對高內聚的操作,提煉到一個獨立的方法中,來分治復雜性。??

使用衛語句

我們知道圈復雜度的一個因素就是分支語句多,我們在寫業務代碼的時候,常見到這樣的一種代碼,if-then-else的層層嵌套。衛語句的原則是,如果某個條件極其罕見,就應該單獨檢查該條件,并在該條件為真時,立刻返回。下面是一個生產中的場景,如果記賬請求落庫成功后就進行余額的操作,如果不成功就返回失敗結果。因為落庫失敗是不常見的,所以我們采用衛語句的方式,來減少分支語句。讓代碼更清晰。

合并條件

經常遇到一種情況,我們對錯誤的處理,需要返回給調用方,內部的錯誤碼,為了方便快讀的定位錯誤會非常詳細,但是對外可能會泛化這種錯誤碼,這個時候我們可以通過合并條件的方式,簡化條件分支,來降低圈復雜度。下面是一個生產中的場景,如果記賬失敗,則對錯誤結果進行包裝處理,并返回給調用方。這個時候我們可以將錯誤碼合并,這里它是合并到map中,然后針對這組錯誤碼統一進行了處理。??

通過多態方式替代條件式

在我們開發中,如果是一個平臺化的系統,很多時候,有這樣的需求。例如:不同的租戶、不同的業務甚至不同的訂單類型都會有不同的處理流程。 這個時候最簡單的方式,就是通過條件分支來進行不同的處理。但是當業務繁多的時候,處理分支會顯得混亂,從而導致圈復雜度的升高,這個時候我們通過利用多態的方式,可以有效的降低復雜度。我們看一下下邊這段代碼,不同的訂單類型,使用不同的處理流程,這里他使用了在枚舉中實現多態的方式。我們發現,其實他是實現了工廠模式。

替換算法

復雜算法會導致bug可能性的增加及可理解性/可維護性的降低,如果函數對性能要求不高,提倡使用簡單明了的算法。這里我引用了重構中的一個例子,我們可以一起看一下。這里傳入一個人名的數組,如果數組中包含指定的名稱,就立即返回名稱。??

分解條件式

在面對大塊頭的代碼時,你可以通過提煉方法的方式,將它分解為多個方法。根據每個小塊代碼的用途,命名新的方法名。對于條件邏輯,將每個分支條件分解成新方法可以突出條件邏輯,并更清楚的表達每個分支的作用。比如下面的例子中,夏季的時候商品的折扣和非夏天的商品折扣,是不同的計算方法。 這個時候,我們可以把兩種算法,提煉到兩個不同的方法中.??

移除控制標記

有時候我們會通過控制標記來對循環進行處理,我們看一下這樣的一段經常使用的代碼,同一個數組列表中查找罪惡的人,匹配到任意一個罪惡的人后返回。這里found是控制標記,我們可通過下邊的方式去掉控制標記,來減少一層循環,達到削減復雜度的效果。

圈復雜度的思辨

那是不是當我們檢測到圈復雜度高的時候他就一定復雜呢,下面的代碼是一個生產上的例子,他通過傳入的MQ的名字,對MQ進行手動的暫停。這個地方實際上是可以通過mq的名稱,從spring的容器中,獲取bean的。這里的例子主要是讓大家看到,雖然,這個分支比較多,但是這種扁平化的結構可讀性還是可以的。不過如果它做的不僅僅是一個暫停的操作,而是一個很復雜的操作,這個時候,可能就需要通過提煉方法的方式進行重構。如果提煉方法重構后,這個類還是過長,那就需要我們通過使用多態的特性,利用工廠模式等方式進行進一步的重構。如果一開始我們就通過應用一些復雜的設計模式進行重構,就會存在過度設計的弊端,使代碼更不易于理解.??

總結

首先介紹了什么是圈復雜度,然后介紹了解決圈復雜度的幾種方法。

通過圈復雜度計算的兩種方式我們可以看到,圈復雜度的核心是分支語句。那解決問題的核心就集中在如何去減少分支語句。

不過最后我們也看到了,實際上,只是刻板的使用圈復雜度的算法,去度量一個段代碼的清晰度,有時候也是不可取的,所以我們在重構系統的時候,可以通過圈復雜度的工具,進行復雜度的統計,然后對復雜度高的代碼,具體場景,具體分析。而不能一味的教條。

最后我們通過思維導圖來梳理一下:??

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2020-12-30 09:20:27

代碼

2022-08-16 09:04:23

代碼圈圈復雜度節點

2019-10-14 17:00:14

前端代碼圈復雜度

2024-06-05 09:35:00

2023-10-05 11:08:53

2024-04-25 08:33:25

算法時間復雜度空間復雜度

2013-08-01 13:18:41

代碼

2015-10-13 09:43:43

復雜度核心

2019-12-24 09:46:00

Linux設置密碼

2024-07-30 10:55:25

2021-09-17 10:44:50

算法復雜度空間

2019-11-18 12:41:35

算法Python計算復雜性理論

2021-10-15 09:43:12

希爾排序復雜度

2021-01-05 10:41:42

算法時間空間

2022-08-25 11:00:19

編程系統

2009-07-09 10:45:16

C#基本概念復雜度遞歸與接口

2018-12-18 10:11:37

軟件復雜度軟件系統軟件開發

2020-02-06 13:59:48

javascript算法復雜度

2019-01-02 05:55:30

領域驅動軟件復雜度

2024-08-22 14:39:34

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩高清一区 | 精品国产欧美一区二区三区成人 | 黄色大片免费看 | 蜜臀网站 | 精品视频一区二区三区在线观看 | 亚洲精品久久久久国产 | 亚洲三区在线观看 | 亚洲精品乱码8久久久久久日本 | 国产精品1区2区3区 欧美 中文字幕 | 欧美一区不卡 | 欧美日韩一区二区在线观看 | av在线一区二区 | 九九亚洲 | 91久久精品| 久久黄视频 | 久久国产综合 | 一呦二呦三呦国产精品 | av在线成人| 中国大陆高清aⅴ毛片 | 日韩午夜在线观看 | 天天操天天射天天舔 | 中文字幕不卡视频在线观看 | 中文字幕在线一区 | 成人国产免费视频 | 免费一区二区 | aⅴ色国产 欧美 | 一区二区精品视频 | 91精品国产综合久久福利软件 | 玖玖玖av | 日韩在线不卡视频 | 成人欧美一区二区三区1314 | re久久 | 成人av激情 | 欧美一区二区三区国产 | 四虎影院免费在线播放 | 久久久噜噜噜久久中文字幕色伊伊 | 中文字幕在线第二页 | 欧美一区二区三区在线观看 | 精品国产欧美一区二区三区成人 | 中文二区 | 99精品国产一区二区三区 |