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

90%的程序員都犯過的代碼錯誤

新聞 前端
最近參加了多次的代碼review會,在review的過程中,發現有些問題幾乎每次都出現。挑了幾個比較典型的問題講解下。

 

最近參加了多次的代碼review會,在review的過程中,發現有些問題幾乎每次都出現。挑了幾個比較典型的問題講解下。這幾個問題都是初級問題,解決方法都很容易。只要掌握了方法,有意識避免,能讓短時間內迅速提高代碼質量。真所謂投入小,見效快。

變量命名不清晰,一詞多義

為變量命名時最重要的考慮事項是,該名字要 完全、準確地描述出該變量所代表的事務 。容易閱讀,不會與其他事務混淆。

例如:

  1. if(staff_id == 0) 
  2.     printf("系統歸檔,不是員工歸檔"); 

上面這段代碼,staff_id是員工號的意思,用staff_id為0表示是系統歸檔。一詞多義,本來應該把系統和人分開,但是混用到了一個變量。如果調用方出現個bug忘記把初始化的變量賦值,還會走到意外的邏輯。

解決方法是變量名稱首先要符合變量的實際意義,沒有歧義;對于一個變量名,不用特定值表示特殊邏輯。

有些代碼會把變量取不到的值賦予其他的意義,感覺是省事了,實際后患無窮。例如用戶名不可能為空,就用空值表示這個用戶數據已經被刪除了。而且判定數據是否刪除的代碼看著也讓人莫名其妙。

總之,變量命名要保證沒有「潛規則」,防止給自己挖坑。

使用魔數

命名不清晰更嚴重的是,沒有命名,直接用魔數。如果連注釋都沒有,就只能靠猜。

使用魔數有兩個不好的地方:

1、不方便修改。

使用常量替換魔數是一種將程序「參數化」的方法,需要修改改動一處就可以了,而不必代碼中到處修改。

例如在代碼中默認綁定的端口是80,如果不用一個常量代替,哪天軟件升級默認端口變成443了。要整個代碼搜索80這個數字,既耗時,又容易改錯。

2、代碼不方便閱讀。

只有一個數字,很難了解到具體的意思。

  1. for(int i = 0; i < 13; ++i) 
  2.     ... 

上面這段代碼,只看13,誰能猜出來是什么意思呢,為什么用13這個數值?可能只有寫代碼的人和上帝知道,如果天長日久,寫代碼的人忘記了,就只有上帝知道了。

也有同學會問,有的數字只用到一個地方,也起個常量的名字會不會太麻煩了?

答案是:不麻煩。給魔數起個好名字是應該的,這是對的事,不要因為麻煩就不做。有時為了起個準確的名字,甚至要查下詞典。

有一個常用的判定方式:

一、如果引用魔數的地方不超過3個,直接用數字影響也不大。如果超過了3個,都是表示同一個數值意義,還是乖乖地用有意義的變量名代替。

二、如果魔數本身就是表示一個純粹的數字定義,例如是幾米、幾千克這種,作為參數傳遞。在函數的定義明確表示了形參數所代表的意義。大家看用到的地方和函數定義,就知道數字是表示多少個單位的意思,可以用魔數。但是如果用數字表示種類,例如

  1. const int ieBrowser=1; 
  2. const int chromeBrowser=2; 

表示瀏覽器的種類,如果直接只是看到1或2,是不明白什么意思的。即使在函數聲明的地方已經說過是瀏覽器種類了,也不要用魔數。

魔數解決的辦法很簡單: 用枚舉、常量等方式,代替魔數 。

if else 或switch等邏輯判斷語句太長

例如下面的偽代碼代碼,條件分支很多,用很長的if else語句或者switch語句才能表達完整的邏輯,要思考下是否能用「表驅動」方式來優化。

  1. const int CN=1; 
  2. const int US=2; 
  3. const int UK=3; 
  4.  
  5. string language; 
  6. if(country==CN) 
  7.     language="中文"
  8. else if(country==US) 
  9.     language="english"
  10. else if(country==UK) 
  11.     language="english"
  12. else 
  13.     language=""

條件分支太多太長有幾點不好:

1、代碼太長,不易閱讀。

如果超過了一個屏幕能表示的長度,要翻頁才能看完代碼,會大大降低看代碼的效率。因為代碼的信息密度太低了。

2、不易擴展,修改代碼。

就像上面的例子,如果又增加了新的條件判斷,那么要增加新的if else語句,由于修改了邏輯,要重新測試,也要防止改錯。

可以用「表驅動」的方式替代太長的邏輯分支。

把每個條件要用到的數據放到一個「表」里。用條件分支的判斷條件來索引到表中的數據。

上面的代碼可以修改為

  1. const int CN=1; 
  2. const int US=2; 
  3. const int UK=3; 
  4.  
  5. string languageTable[]={"","中文","English","English"}; 
  6. //先判斷country變量是否在定義的CN、US、UK范圍內,如果在繼續 
  7. language = languageTable[country]; 

經過修改,代碼變得很短,一眼就能看出代碼所表示的邏輯。而且以后更新的只有數據,邏輯部分不用修改。

使用「表驅動」后,邏輯和數據分離。使得新增數據修改簡單,而且一目了然。

總結

上面只是簡單的說明了幾種常見的代碼書寫錯誤。稍加注意,就能夠在短時間內迅速提升代碼質量。具體的方法可以參考一些代碼規范,或者重構的書籍,例如「表驅動」會有更詳盡的介紹。

最本質的還是要從意識上有足夠的認識。 代碼是寫給人看的 ,寫代碼時要有同理心,想到以后讓閱讀代碼的人盡量能夠不費力讀懂。換位思考,如果你就是review人,或后面接手這個代碼的人,你會喜歡這段代碼嗎?

畢竟代碼閱讀的次數遠遠超過編寫的次數。確保代碼閱讀方便,而不僅是編寫方便。

 

責任編輯:張燕妮 來源: 架構學而思
相關推薦

2015-03-02 15:30:11

2015-04-17 09:47:57

2011-06-29 09:27:10

2019-08-22 10:07:33

程序員開發危機

2018-10-15 09:50:07

程序員高薪淘汰

2021-11-02 09:54:51

Java開發工具

2020-04-20 18:15:46

開發自信技術

2021-09-28 09:57:50

程序員技能開發

2016-12-06 10:12:07

程序員開會

2020-05-17 16:10:36

開發人員軟件開發開發

2022-10-17 07:40:21

AI項目數據

2017-03-13 09:07:05

測定代碼基因

2017-11-14 11:28:49

程序員索引數據

2022-07-20 16:57:18

程序員高薪職業

2013-08-20 09:33:59

程序員

2019-07-03 14:47:43

程序員祼辭就業

2019-07-05 11:05:10

Java程序員中間件

2018-07-20 11:22:03

程序員基礎知識

2015-06-17 14:24:48

優秀程序員整潔代碼

2014-09-24 09:37:05

程序員
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久69精品久久久久久国产越南 | 黑人一级黄色大片 | 国产精品1区2区3区 男女啪啪高潮无遮挡免费动态 | 亚洲婷婷六月天 | 伊人免费视频二 | 久草免费在线 | www久久久 | 色综合色综合色综合 | a级性视频 | 国产美女久久久 | 国产成人精品一区二区三区网站观看 | 中文字幕亚洲视频 | 一区二区三区四区av | 国内精品久久久久久影视8 最新黄色在线观看 | 国产特一级黄色片 | 亚洲天堂中文字幕 | 欧美午夜一区二区三区免费大片 | 美女黄视频网站 | 久久日韩精品一区二区三区 | 欧美影院 | 天天操夜夜艹 | 成人高清在线 | www.日韩 | 日日淫 | 日韩欧美在线视频 | 天天爽天天操 | 国产2区| 亚洲在线免费 | 日韩精品在线网站 | av福利网站 | 亚洲精品18 | 一区二区三区四区在线 | 日韩精品一区在线观看 | 欧美精品在线观看 | 亚卅毛片 | 国产成视频在线观看 | 午夜在线视频 | 中文字幕日本一区二区 | 欧美精品区 | 国产999精品久久久久久 | 日韩国产一区二区三区 |