• <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>

            love in C++, live on MFC

            to get ready...

            C++博客 首頁 新隨筆 聯系 聚合 管理
              47 Posts :: 0 Stories :: 97 Comments :: 0 Trackbacks

            書上說匈牙利命名法已經過時了,我不這樣認為。

            有人認為現在編譯器已經可以很好的檢測出類型的不匹配,或者IDE中可以很快的看到類型,所以在c中可能需要,在C++(強類型語言)中就不需要了。
            C++ made it harder to do that without wicked casting and the compiler catches most of those kind of errors.? So, I agree with the previous poster that it's now redundant.
            Also, modern IDEs allow you to hover the cursor over a variable and show you the variable's definition.


            不過我覺得代碼不是寫給編譯器看的,而是寫給人看的,這里就有self-documenting和readability的問題。
            很明顯,如果你看到nIndex 或者strFile或者wndNext,就可以很快知道分別是int CString CWnd類型,而不用回頭去看變量定義,這樣,看代碼時就會很快。
            而且,對于MFC程序員來說,更重要一些,因為MFC里面的變量都是用匈牙利命名法的。
            If you're programming C++/MFC you're better sticking to hungarian for consistency with the class library & Win32 API declarations.
            微軟的約定,就是標準了

            不過,書上提到在泛型編程中不需要,現在體會還不深,可能是對的。

            今天(2006 04 13碰巧看到codeproject的一個vote),結果如下

            Option Votes %
            Pascal Cased 171 10.6
            camel Cased 702 43.4
            Fixed letter prefix (eg lLocal) 81 5.0
            Hungarian prefix (eg strLocal) 481 29.7
            Scope prefix (eg l_Local) 36 2.2
            Scope and Hungarian prefix (eg l_strLocal) 125 7.7
            Responses 1618 ?

            Hungarian Notation排第二.
            cp上面有兩個鏈接
            Conversations: Hungarian wartHogs (http://www.cuj.com/documents/s=7989/cujcexp1911hyslop/hyslop.htm)
            號稱這篇文章就已經明白的說HN過時了(作者也是c++ coding stardard的作者).
            如果不用HN,那么應該用什么樣的命名規則呢?
            Naming Guidelines(http://msdn.microsoft.com/library/default.asp?url=/library/en-us/cpgenref/html/cpconNamingGuidelines.asp)
            .Net下的推薦,也許別的地方也可以用.
            posted on 2006-04-05 19:45 flyingxu 閱讀(605) 評論(5)  編輯 收藏 引用 所屬分類: C++ Coding Standards

            Feedback

            # re: Is Hungarian notation obsolete? 2006-04-07 10:20 小明
            對于變量命名,我的原則就是入鄉隨俗

            寫MFC程序就用匈牙利
            寫Java程序就用Java命名
            寫Linux程序大部分都用小寫和下劃線
            改別人的程序就按別人的標準

            總之,目標是使代碼看起來是一個人寫的。  回復  更多評論
              

            # re: Is Hungarian notation obsolete? 2006-04-11 16:11 ace
            編碼規范要看你是站在哪層面上來看.
            如果全是VC+MFC,那用Hungarian style的就足夠了.

            但是,我以前也是Hungarian的"支持"者,但后來發現它有太多的與編碼規范其它條款抵觸的地方.現在我也不支持它了.

            清晰、可理解的 C++ 源代碼是規則和指南的主要目標:清晰、可理解的源代碼是軟件可靠性和可維護性的主要作用因素.
            清晰、可理解的代碼可以表示為以下三個簡單的基礎原理
            最小混淆 - 它的生存期中,源代碼的讀遠比寫多,規約更是這樣。理想情況下,源代碼讀起來應該象英語一樣描述了所要做的事,這同時還帶來了它執行的好處。程序更多是為人編寫,而不是為計算機而編寫。閱讀代碼是一個復雜的腦力過程,它可由統一標準來簡化,在本文中還指最小混淆原則。整個項目中統一樣式是軟件開發團隊在編程標準上達成一致的主要原因,它不應視為一種懲罰或對創造性和生產力的阻礙。
            維護的唯一點 - 只要可能,設計決策就應在源中只表述一點,它的多數后果應程序化的派生于此點。不遵守這一原則嚴重損害了可維護性、可靠性和可理解性。
            最小干擾 - 最終,應用最小干擾原則(它是易讀性的主要作用因素)。即,避免將源代碼與可視干擾(如內容較少或對理解軟件目的不起作用的信息)相混合:

            去年得了jolt大獎的 C++ Coding Standards 一書
            http://www.huachu.com.cn/2006/c++.htm

            也把Hungarian 樣式的風格作了批評.


              回復  更多評論
              

            # re: Is Hungarian notation obsolete? 2006-04-13 16:20 flyingxu
            @ace
            很感興趣你回復中的觀點,能有具體例子說明一下嗎?

            估計HN真的正在慢慢的過時,在codeproject中的一個vote中,HN排第二.
            http://www.codeproject.com/script/survey/detail.asp?survey=554
              回復  更多評論
              

            # re: Is Hungarian notation obsolete? 2006-04-14 09:57 Stone Jiang
            @flyingxu
            有空多交流這個話題,我要整理之后才能給出一個自已覺得滿意點的回復.
            晚些時候再來個詳細的.   回復  更多評論
              

            # re: Is Hungarian notation obsolete? 2006-05-12 09:13 ztwaker
            我贊成小明的意見。  回復  更多評論
              

            四虎国产精品免费久久5151| 国产精品久久久久jk制服| 久久91精品综合国产首页| 久久久无码精品亚洲日韩京东传媒| 欧美喷潮久久久XXXXx| 久久久久久久国产免费看| 国产欧美一区二区久久| 人妻丰满AV无码久久不卡| 久久精品国产只有精品2020| 久久久久亚洲AV成人网人人网站| 亚洲AV无码成人网站久久精品大| 亚洲精品乱码久久久久久不卡| 99久久综合国产精品二区| 久久超乳爆乳中文字幕| 久久精品国产99久久久| 亚洲精品无码久久不卡| 亚洲国产成人久久综合一 | 亚洲欧美一区二区三区久久| 国产免费久久久久久无码| 欧美一区二区三区久久综| 久久久久亚洲AV成人网| 国产69精品久久久久99| 久久久久99精品成人片欧美| 99精品国产99久久久久久97| 久久香综合精品久久伊人| 伊人情人综合成人久久网小说| 99久久国产综合精品五月天喷水| 国产精品视频久久久| 久久亚洲国产欧洲精品一| 久久久久亚洲精品无码蜜桃| 狠狠色狠狠色综合久久| 久久丫忘忧草产品| 99国产欧美久久久精品蜜芽| 亚洲精品无码久久千人斩| 久久综合亚洲鲁鲁五月天| 久久综合视频网| 亚洲中文精品久久久久久不卡| 国产偷久久久精品专区 | 狠狠精品干练久久久无码中文字幕 | 精品多毛少妇人妻AV免费久久| 久久精品国产亚洲一区二区|