程序員最頭疼的事:命名

作者: Phil Johnson  來源: 伯樂在線  發布時間: 2013-11-05 21:53  閱讀: 18084 次  推薦: 40   原文鏈接   [收藏]  

  原文鏈接: Don’t go into programming if you don’t have a good thesaurus

  許多程序員認為編程時,如何命名不僅是他們面臨的老大難問題,也是最重要的事情之一。

  上周,我發起了一個“程序員編程中的老大難問題”的投票,主要是基于最近Quora上的跟帖討論。根據大家的反響和投票結果,有一項投票遙遙領先,穩居第一——對于軟件開發人員來說,最大的難題是:如何命名(例如:給變量,類,函數和過程命名等等)。

  對于這個結果,我多少有點意外,因為作為一個多年的開發人員,我不會投給這一項(我想我會投給“修改或維護別人的代碼”)。但是真正讓我驚訝的是,看起來好像不怎么重要的命名居然排列第一,跟期待的結果實在差太遠了。下面是投票結果的分布圖。

  該結果是來自Quora問答網站和更早的Ubuntu論壇跟帖的4500個開發者的投票。“如何命名”一項的選票幾乎是其它八項的投票結果的總和,哇!

  的確,這些基于自我篩選的群體的投票結果是完全不科學的。但是我認為這個結果還是有一定意義的,換句話說,如何命名的確是個很棘手的問題,許多非編程人員可能會意識不到。

  幾年前在StackExchange社區里對于這個話題剛好有個跟帖,為了強調這一點,我引用了一些內容是關于程序員在編程中對于命名的的痛苦和糾結。

  “我確實在編程的時候花了很多時間在考慮如何命名。” 

  “我不得不同意命名是一門藝術。” 

  “如果你想要提高代碼的可讀性,命名的確很重要。” 

  我認為最后一條抓住了部分核心,解釋了命名為什么會這么難,因為它太重要了。準確的命名可以提高代碼的可讀性,讓人容易理解,方便調試,也給以后修改和維護你的代碼的人帶來方便。一旦開始做了,很快你會發現要想出一個簡潔又準確的名字沒那么容易。就像Jeff Atwood 所寫的:

  “想出好的命名的確很難,但是有難的道理,因為好的命名需要只用一兩個單詞出表達你的根本意思。” 

  而且,許多人認為,正確的命名能幫你寫出好的代碼。如果不能為一個變量或者函數想出一個清晰又簡潔的名字,那可能是你的代碼有問題。那樣的話,你就得考慮重寫或者進行代碼重構了。

  “通常,如果你無法想出一個合適的名字,意味著你的設計可能有問題。你的一個方法里是不是實現了太多的功能?或者你的類的封裝,凝聚性不夠強?” 

  “我的經驗是如果無法給你的類想出一個合適的名字,大多數情況都是你的類有問題:你可能不需要這個類,它有點多余了” 

  “命名難也不見得是壞事兒,它可以迫使你去認真思考你的類到底想要實現什么功能。”

  長話短說:如果你想要學習編程,一定要給自己準備一本好詞典。 

  ——————

  原文鏈接: Phil Johnson    翻譯: 伯樂在線 - JingerJoe
  譯文鏈接: http://blog.jobbole.com/50708/

40
1
 
標簽:程序員 命名
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()