青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

幽幽
 
posts - 51,  comments - 28,  trackbacks - 0
抨擊匈牙利命名法

匈牙利命名法是一種編程時的命名規(guī)范。命名規(guī)范是程序書寫規(guī)范中最重要也是最富爭議的地方,自古乃兵家必爭之地。命名規(guī)范有何用?四個字:名正言順。用二分法,命名規(guī)范分為好的命名規(guī)范和壞的命名規(guī)范,也就是說名正言順的命名規(guī)范和名不正言不順的命名規(guī)范。好的舞鞋是讓舞者感覺不到其存在的舞鞋,壞的舞鞋是讓舞者帶著鐐銬起舞。一個壞的命名規(guī)范具有的破壞力比一個好的命名規(guī)范具有的創(chuàng)造力要大得多。

本文要證明的是:匈牙利命名法是一個壞的命名規(guī)范。本文的作用范圍為靜態(tài)強類型編程語言。本文的分析范本為C語言和C++語言。下文中的匈法為匈牙利命名法的簡稱。

一 匈牙利命名法的成本

匈法的表現(xiàn)形式為給變量名附加上類型名前綴,例如:nFoo,szFoo,pFoo,cpFoo分別表示整型變量,字符串型變量,指針型變量和常指針型變量。可以看出,匈法將變量的類型信息從單一地點(聲明變量處)復(fù)制到了多個地點(使用變量處),這是冗余法。冗余法的成本之一是要維護副本的一致性。這個成本在編寫和維護代碼的過程中需要改變變量的類型時付出。冗余法的成本之二是占用了額外的空間。一個優(yōu)秀的書寫者會自覺地遵從一個法則:代碼最小組織單位的長度以30個自然行以下為宜,如果超過50行就應(yīng)該重新組織。一個變量的書寫空間會給這一法則添加不必要的難度。

二 匈牙利命名法的收益

這里要證明匈牙利命名法的收益是含糊的,無法預(yù)期的。

范本1:strcpy(pstrFoo,pcstrFoo2) Vs strcpy(foo,foo2)
匈法在這里有什么收益呢?我看不到。沒有一個程序員會承認自己不知道strcpy函數(shù)的參數(shù)類型吧。

范本2:unknown_function(nFoo) Vs unknown_function(foo)
匈法在這里有什么收益呢?我看不到。對于一個不知道確定類型的函數(shù),程序員應(yīng)該去查看該函數(shù)的文檔,這是一種成本。使用匈法的唯一好處是看代碼的人知道這個函數(shù)要求一個整型參數(shù),這又有什么用處呢?函數(shù)是一種接口,參數(shù)的類型僅僅是接口中的一小部分。諸如函數(shù)的功能、出口信息、線程安全性、異常安全性、參數(shù)合法性等重要信息還是必須查閱文檔。

范本3:nFoo=nBar Vs foo=bar
匈法在這里有什么收益呢?我看不到。使用匈法的唯一好處是看代碼的人知道這里發(fā)生了一個整型變量的復(fù)制動作,聽起來沒什么問題,可以安心睡大覺了。如果他看到的是nFoo=szBar,可能會從美夢中驚醒。且慢,事情真的會是這樣嗎?我想首先被驚醒的應(yīng)該是編譯器。另一方面,nFoo=nBar只是在語法上合法而已,看代碼的人真正關(guān)心的是語義的合法性,匈法對此毫無幫助。另一方面,一個優(yōu)秀的書寫者會自覺地遵從一個法則:代碼最小組織單位中的臨時變量以一兩個為宜,如果超過三個就應(yīng)該重新組織。結(jié)合前述第一個法則,可以得出這樣的結(jié)論:易于理解的代碼本身就應(yīng)該是易于理解的,這是代碼的內(nèi)建高質(zhì)量。好的命名規(guī)范對內(nèi)建高質(zhì)量的助益相當有限,而壞的命名規(guī)范對內(nèi)建高質(zhì)量的損害比人們想象的要大。

三 匈牙利命名法的實施

這里要證明匈牙利命名法在C語言是難以實施的,在C++語言中是無法實施的。從邏輯上講,對匈法的收益做出否定的結(jié)論以后,再來論證匈法的可行性,是畫蛇添足。不過有鑒于小馬哥曾讓已射殺之敵死灰復(fù)燃,我還是再踏上一支腳為妙。

前面講過,匈法是類型系統(tǒng)的冗余,所以實施匈法的關(guān)鍵是我們是否能夠精確地對類型系統(tǒng)進行復(fù)制。這取決于類型系統(tǒng)的復(fù)雜性。

先來看看C語言:

1.內(nèi)置類型:int,char,float,double 復(fù)制為 n,ch,f,d?好像沒有什么問題。不過誰來告訴我void應(yīng)該怎么表示?
2.組合類型:array,union,enum,struct 復(fù)制為 a,u,e,s?好象比較別扭。
這里的難點不是為主類型取名,而是為副類型取名。an表示整型數(shù)組?sfoo,sbar表示結(jié)構(gòu)foo,結(jié)構(gòu)bar?ausfoo表示聯(lián)合結(jié)構(gòu)foo數(shù)組?累不累啊。
3.特殊類型:pointer。pointer在理論上應(yīng)該是組合類型,但是在C語言中可以認為是內(nèi)置類型,因為C語言并沒有非常嚴格地區(qū)分不同的指針類型。下面開始表演:pausfoo表示聯(lián)合結(jié)構(gòu)foo數(shù)組指針?ppp表示指針的指針的指針?

噩夢還沒有結(jié)束,再來看看類型系統(tǒng)更阿為豐富的C++語言:

1.class:如果說C語言中的struct還可以用stru搪塞過去的話,不要夢想用cls來搪塞C++中的class。嚴格地講,class根本就并不是一個類型,而是創(chuàng)造類型的工具,在C++中,語言內(nèi)置類型的數(shù)量和class創(chuàng)造的用戶自定義類型的數(shù)量相比完全可以忽略不計。stdvectorFoo表示標準庫向量類型變量Foo?瘋狂的念頭。
2.命名空間:boostfilesystemiteratorFoo,表示boost空間filesystem子空間遍歷目錄類型變量Foo?程序員要崩潰了。
3.模板:你記得std::map<std::string,std::string>類型的確切名字嗎?我是記不得了,好像超過255個字符,還是饒了我吧。
4.模板參數(shù):template <class T, class BinaryPredicate>const T& max(const T& a, const T& b, BinaryPredicate comp) 聰明的你,請用匈法為T命名。上帝在發(fā)笑。
5.類型修飾:static,extern,mutable,register,volatile,const,short,long,unsigned 噩夢加上修飾是什么?還是噩夢。
posted on 2008-05-02 02:26 幽幽 閱讀(2589) 評論(10)  編輯 收藏 引用 所屬分類: 雜集

FeedBack:
# re: 抨擊匈牙利命名法
2008-05-02 08:22 | lovedday
早就放棄匈牙利命名法了,匈牙利命名法可能在開發(fā)windows API的時候有用,那時的編譯器的變量和函數(shù)提示功能沒有那么強大,程序員可以從匈牙利命名法中得到好處。可是現(xiàn)在編譯器的信息提示功能已經(jīng)非常強大,匈牙利命名法實際上是一種累贅,帶來的弊端遠遠超過它的好處,不利于代碼閱讀。  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2009-08-11 11:22 | 合體星人
盡管樓主如此抨擊匈牙利命名法,那為什么不提出一個更有效的命名系統(tǒng)?  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2009-08-31 11:14 | 12311
是這樣的,團隊開發(fā)時必須有一個命名規(guī)范,而自己制定一整套規(guī)范的話既麻煩又產(chǎn)生大量學(xué)習(xí)成本,新成員加入后首先要讓他適應(yīng)新的規(guī)范,按照經(jīng)驗看,改變一個程序員的命名規(guī)范是很花時間的,所以往往都是采用大家認知度較高的一種既存規(guī)范,所以首選仍然是匈牙利。
另:沒有大型團隊合作項目經(jīng)驗的人沒有資格對規(guī)范的東西提出抨擊~~~  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2009-11-09 19:30 | 曉宇
我很是期待看到你用100個i做變量的表情.
希望我不會碰到你寫的程序

但是說實話,你很厲害,寫這么多.而且還找了例子,從這點來說 確實很厲害.  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2010-03-09 16:29 | koangel
如果你們?nèi)ゾS護過其他人的代碼,或參與過較大型產(chǎn)品的開發(fā),就絕對不會這么說了,對于你們這種只會自己編碼的人,怎么可能理解的到其中的內(nèi)涵?井底之蛙  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2010-04-23 13:04 | cvb
@合體星人
java程序員沒有聽說過所謂的命名法,但java程序的可讀性仍然是最強的。
匈牙利命名法對VC程序有毀滅性的打擊  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2010-06-05 00:45 | 不想多說你了
無知~~  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2010-08-10 20:36 | #
對你無話可說,只能說你無知  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法[未登錄]
2012-04-10 13:42 | Alex
慶幸樓主不是我同事
更慶幸樓主不是我老大  回復(fù)  更多評論
  
# re: 抨擊匈牙利命名法
2013-03-15 10:56 | Linuxer
Linus 本人說匈牙利命名法是brain damaged 很中肯!
  回復(fù)  更多評論
  

<2009年3月>
22232425262728
1234567
891011121314
15161718192021
22232425262728
2930311234

常用鏈接

留言簿(6)

隨筆分類(35)

隨筆檔案(51)

文章分類(3)

文章檔案(3)

相冊

我的鏈接

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲精品网站在线播放gif| 亚洲国产91| 国产精品一区二区你懂的| 欧美久色视频| 欧美精品激情在线| 欧美精品一区二区三| 欧美日本成人| 国产精品久久久久久户外露出| 国产精品一区免费视频| 黄色成人在线观看| 亚洲品质自拍| 亚洲免费影视| 久久久女女女女999久久| 鲁大师影院一区二区三区| 亚洲第一精品影视| 亚洲视频日本| 久久免费一区| 欧美婷婷在线| 在线播放一区| 亚洲欧美成人| 亚洲国产精品久久久久久女王| 亚洲一区二区免费在线| 欧美成人午夜77777| 国产精品婷婷| 亚洲乱码精品一二三四区日韩在线| 亚洲欧美激情精品一区二区| 免费一级欧美片在线观看| 一区二区三区产品免费精品久久75| 久久精品午夜| 国产美女精品视频| av成人免费观看| 看片网站欧美日韩| 亚洲欧美日本国产有色| 欧美精品久久久久久久免费观看| 国产精品永久免费| 日韩视频一区二区三区在线播放 | 欧美日韩亚洲一区二区| 国产日韩av在线播放| 免费在线亚洲| 欧美日韩国产a| 黄色一区二区三区| 午夜伦欧美伦电影理论片| 亚洲国产成人不卡| 久久精品72免费观看| 国产精品色婷婷| 99精品免费视频| 亚洲高清久久久| 久久人人超碰| 国产人成精品一区二区三| 在线亚洲一区| 亚洲免费观看在线观看| 蜜臀av国产精品久久久久| 精品999成人| 久久久蜜臀国产一区二区| 亚洲男女自偷自拍| 国产精品极品美女粉嫩高清在线| 亚洲精品欧美日韩| 欧美国产综合视频| 免费成人美女女| 最新中文字幕亚洲| 亚洲国产aⅴ天堂久久| 久久精品电影| 黄色精品一二区| 黄色一区二区三区| 久久亚洲精品欧美| 久久综合网络一区二区| 91久久久国产精品| 亚洲日本中文| 99精品国产福利在线观看免费 | 红桃av永久久久| 欧美在线播放视频| 亚洲图片在线观看| 国产精品一区二区三区四区| 久久成人18免费网站| 久久成人免费| 亚洲第一页自拍| 亚洲电影在线播放| 欧美日韩成人综合| 欧美一区成人| 久久美女性网| 亚洲经典自拍| 欧美精品日韩一本| 亚洲精品美女久久7777777| 亚洲国产精品黑人久久久| 六月丁香综合| 一区二区国产日产| 午夜精品国产更新| 亚洲国产成人精品视频| 伊人久久大香线| 乱中年女人伦av一区二区| 老牛影视一区二区三区| 亚洲剧情一区二区| 亚洲视频免费在线| 国产资源精品在线观看| 欧美激情一区二区三区在线视频 | 免费欧美日韩| 亚洲精品中文字幕在线| 欧美电影在线观看| 亚洲一区在线视频| 久久精视频免费在线久久完整在线看| 在线观看一区二区视频| 99在线精品免费视频九九视| 国产一区在线视频| 亚洲精品综合久久中文字幕| 国产日韩欧美麻豆| 亚洲精品乱码久久久久久蜜桃91| 国产乱码精品一区二区三区av| 欧美成人首页| 国产精品久久久久久久久久尿| 欧美成人四级电影| 国产日产欧产精品推荐色 | 亚洲国产精品视频一区| 国产亚洲精品7777| 一区二区激情小说| 在线日韩中文字幕| 亚洲免费在线观看视频| 日韩一级免费观看| 久久综合精品国产一区二区三区| 午夜国产精品视频免费体验区| 免费不卡在线观看av| 久久综合一区二区三区| 国产日韩欧美精品综合| 一区二区三区视频在线播放| 亚洲毛片在线| 久久久久久久综合| 午夜在线观看欧美| 欧美视频在线观看一区| 亚洲精品久久久久| 亚洲精品免费一区二区三区| 久久久欧美精品sm网站| 久久久91精品| 欧美日韩www| 亚洲欧美国产精品桃花| 亚洲精品日韩在线观看| 午夜精品久久久久久99热| 亚洲天堂免费观看| 欧美日韩国产综合视频在线观看中文 | 欧美极品在线视频| 欧美不卡高清| 有坂深雪在线一区| 久久国产主播| 快播亚洲色图| 伊人成人在线| 美乳少妇欧美精品| 亚洲国产高潮在线观看| 亚洲精品一区中文| 欧美激情精品久久久久| 亚洲精品在线观| 欧美午夜精品久久久| 99riav1国产精品视频| 亚洲欧美精品| 国产自产在线视频一区| 久久精品亚洲| 亚洲高清不卡在线观看| 一区二区三区回区在观看免费视频| 欧美另类视频| 亚洲综合视频网| 久久夜色撩人精品| 亚洲精品国久久99热| 欧美日本簧片| 亚洲天堂久久| 噜噜噜在线观看免费视频日韩| 在线观看一区欧美| 欧美精品一区二区三区一线天视频| 亚洲毛片在线看| 欧美有码在线视频| 亚洲国内自拍| 国产精品一区二区三区观看| 久久久久这里只有精品| 亚洲精品在线看| 久久精品国产视频| 亚洲精品欧美在线| 国产日韩精品视频一区二区三区| 狼狼综合久久久久综合网| 亚洲精品久久久久久久久久久久久 | 亚洲无线一线二线三线区别av| 国产欧美日韩在线| 欧美激情91| 欧美一区2区视频在线观看| 亚洲电影专区| 久久精品水蜜桃av综合天堂| 亚洲精品欧美| 国产在线精品二区| 欧美亚洲第一区| 美国十次成人| 午夜欧美大片免费观看| 亚洲精选一区二区| 蜜臀久久99精品久久久久久9 | 午夜精品久久久久久久99黑人| 亚洲成人中文| 国产欧美日韩综合精品二区| 欧美片在线观看| 久久精品电影| 亚洲欧美日韩一区在线| 艳妇臀荡乳欲伦亚洲一区| 欧美激情第8页| 久久亚洲风情| 久久午夜电影网| 欧美自拍丝袜亚洲| 亚洲欧美一区二区激情|