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

程序員談編碼質量與命名

開發 開發工具
不少程序員以為提高編碼質量,需要很多激動人心的創新,需要明顯的飛躍,這也許對,但我個人感覺項目中提高編碼質量是個水磨功夫,要一步步積累,方法論大多時候幫助不大。

這次先從命名說起。

當我們看到一份設計圖或一份代碼時,大多數人會【望文生義】。但使人【望文生義】卻正是語言文字的根本使命。

因此,如果一個函數被命名為Add(),但內部實際做的是減法,那么這份設計或者這份代碼,一定是很難理解的。

于是一個非常現實的問題就擺在了我們的面前:我們究竟應該如何為類,為方法等等命名?

以命名而論,有兩個較大的陷阱:一個是名實不符,一個是詞義混淆。

名實不符的常見情形又有兩類。比如:

以偏概全。假設說一個方法被命名為OutputLineNumber(),但實際上這個方法會在分析源文件后,同時輸出LineNumber和指定行號下的內容大而無當。假使說一個類被命名為XMLHandler,那么看得人基本不能從這個名字上獲得有效信息。這主要是由于Handler這個詞的含義過于寬泛。 

上文所說的命名為Add()但實際做減法操作是名實不符的極端情形,達到了名實相反的地步。

詞義混淆則源自語言文字自身的限制。常表現為一詞多義或多詞一義。

語言文字可以被看成是一種表意的符號系統,這個符號系統的典型特征是其模糊性。

同一個意思可以有許多種表達方法。比如說:index和number是兩個不同的詞,但很多時候其意義互相重疊。而假如說一個變量名為fileNumber,那么這個變量既可以代表文件的總數,也可以代表某個具體文件的編號。

上述問題會因為英語不是我們的母語而變得更為麻煩。

名實不符與詞義混淆這類陷阱的一個主要觸發條件是軟件自身的不停衍化。

在之前的文章里曾經提到過,對于概念和邏輯的認知是一個逐層遞進的過程。

在這一過程中,包,類,方法等的內涵必然會發生變更。變更無疑的會使名實不符這類問題加劇。比如:一個類原本負責輸出測試結果,這時候OutputTestResult這樣的命名可能是合適的。可隨著軟件功能的增強,最終可能不知要輸出結果,還要對結果進行一定分析和統計。這樣原來的命名就顯的有些不合適了。

在對命名這一問題的根源進行分析之后,我們來看看可能的應對方法。

命名問題事實上并不能只在命名這一環節進行解決,首先要有容易命名的對象,接下來才有容易命名的事實。

比如說:是先有貓和狗這類外在特征不同的動物,接下來我們才用貓和狗這樣不同的名字來稱呼他們,而非相反。

如果概念之間是正交的,概念的邊界也是清晰的,那么命名無疑會容易很多。好的設計是改善命名的基礎。

也就是說,很多時候我們感到命名困難,真正原因可能并非是命名的技能不夠,而是設計還不夠優化。

在努力改善設計之后,才需要面對純粹的命名問題。

從本質上來看,命名問題并不是一個編程的問題,而是一個表達的問題。命名最終對讀程序的人負責。

有些表達上的基本原則對于解決命名問題會有些幫助,比如:

尊重既成事實 

無疑的每個人都是有創造性的,但在命名的時候發揮創造性則更可能是有害的。比如說:在XML的世界中一般使用sibling這個詞來表示兄弟節點,這種時候就不需要創造性的使用brother node這樣的自制詞匯了。

用完整詞匯 

對一般人而言要求事先記憶幾十個縮寫詞,而后來讀程序是不太可能的事情。所以如果一個程序中充滿_Tx和CSCP這樣的特制符號的話,那這樣的程序幾乎一定是不容易懂的。

一個典型的反例是P.J Plauger版的C++標準模板庫。也許是出于隱藏實現細節的目的,這份標準模板庫的實現里面幾乎完全不用完整詞匯。如果想體驗一下不用完整詞匯的后果,那么可以讀一下這里面的代碼。

要具體 

具體是一個方向。

比如說:可以用OutputLinenumber()的時候,就不要用Output()。而可以用OutputCppLinenumber()的時候就不要用OutputLinenumber()。

 多人協作的時候,使用統一規范 

這條規則最終會導致常說的Coding Rule。對具體如何定義Coding Rule,《代碼大全》一書中給出了詳細的指導,這里就不在說明了。

有一點需要補充的是,就和說話的時候記不住語法一樣,設計或做編碼的人往往也記不住編碼規則。所以規則也不宜過多。如果必須詳細,那么至少要主次分明。比如說:統一使用主賓結構還是使用動賓結構這樣的選擇會影響程序的大部分內容,那么就應該優先統一。

原文鏈接:http://www.cnblogs.com/daoshi/archive/2012/04/23/2465812.html

【編輯推薦】

  1. 程序員需要謹記的九大安全編碼規則
  2. 如何優化Java程序設計和編碼提高性能
  3. Swing多線程編碼過程中的誤區
  4. 缺乏想象力的程序員
  5. 一個老程序員的十年回顧
責任編輯:彭凡 來源: 博客園
相關推薦

2012-07-12 09:31:49

程序員

2009-03-20 10:06:21

程序員PHP職場

2013-05-30 13:30:00

代碼效率程序員

2013-11-01 17:24:39

程序員命名

2013-07-15 13:45:16

程序員

2023-09-07 09:46:44

程序員編程

2012-04-27 09:24:44

程序員編碼員

2013-03-12 10:44:01

程序員

2013-05-02 08:57:04

程序員創業

2018-01-23 09:37:59

程序員面試薪資

2010-12-16 11:05:36

數學程序員Google首席Jav

2020-02-25 15:14:13

程序員人生第一份工作睡眠

2021-01-09 22:35:51

程序員編碼代碼

2020-03-09 11:14:25

程序員技術設計

2013-08-20 09:33:59

程序員

2012-03-06 09:22:46

程序員

2019-03-05 14:37:55

程序員加薪老板

2018-01-02 09:36:55

程序員加薪年終

2010-05-12 16:19:32

程序員面試經驗

2015-04-20 09:50:58

程序員
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人一区二区三区视频 | 国产精品亚洲一区 | 精品一区二区三区四区五区 | 国产95在线| 亚洲超碰在线观看 | 天天射天天操天天干 | 啪一啪在线视频 | 91国内在线观看 | 久久99久久98精品免观看软件 | 97av视频在线观看 | 色婷婷综合成人av | 久国久产久精永久网页 | 中文字字幕一区二区三区四区五区 | 亚洲人人舔人人 | 精品综合久久久 | a级毛片基地 | 国产免费福利在线 | 欧美激情区| 亚洲欧美综合 | 99精品视频一区二区三区 | 国产精品高潮呻吟久久 | 欧美日韩免费 | 欧美h| 久久久av一区 | 一区二区三区在线免费看 | 亚洲激情在线视频 | 高清国产一区二区 | 日韩精品久久久 | 亚洲在线一区二区 | 夜久久| 午夜影院在线观看视频 | 看av网址 | 欧美综合精品 | 成人av电影免费在线观看 | 欧美一区二区三区在线观看视频 | 国产午夜精品一区二区三区四区 | 国产成人av电影 | 成人av免费| 在线电影日韩 | 国产精品18hdxxxⅹ在线 | 欧洲成人 |