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

            C小加

            厚德 博學(xué) 求真 至善 The bright moon and breeze
            posts - 145, comments - 195, trackbacks - 0, articles - 0
              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            避免使用宏

            Posted on 2011-11-19 13:52 C小加 閱讀(13335) 評(píng)論(6)  編輯 收藏 引用

            概述:

                    宏是C和C++語(yǔ)言的抽象設(shè)施中最生硬的工具,它是披著函數(shù)外衣的饑餓的狼,很難馴服,它會(huì)我行我素地游走于各處。要避免使用宏。

            討論:

                    在C++中,幾乎從不需要使用宏。

                    可以用const或者enum定義易于理解的常量,用inline避免函數(shù)調(diào)用的開(kāi)銷(xiāo),用template指定函數(shù)系列和類(lèi)型系列,用namespace避免名稱(chēng)沖突。

                C++的宏的主要問(wèn)題在于,它們表面上看起來(lái)很好,而實(shí)際上做的卻是另一回事。宏會(huì)忽略作用域,忽略類(lèi)型系統(tǒng),忽略所有其他的語(yǔ)言特性和規(guī)則,而且會(huì)劫持它為文件其余部分所定義(#define)的符號(hào)。宏調(diào)用看上去很像符號(hào)或者函數(shù)調(diào)用,但實(shí)際上并非如此。宏不太“衛(wèi)生”,也就是說(shuō),它會(huì)根據(jù)自己被使用時(shí)所處的環(huán)境引人注目而且令人驚奇地展開(kāi)為各種東西。宏需要進(jìn)行文本替換,因此編寫(xiě)遠(yuǎn)距離也正確的宏接近于一種魔法,而精通這種魔法既無(wú)意義又無(wú)趣味。

                不少人認(rèn)為與模板相關(guān)的錯(cuò)誤都是最難以解讀的,他們可能還沒(méi)有看到誤寫(xiě)和誤用的宏所引起的那些錯(cuò)誤。模板是C++類(lèi)型系統(tǒng)的一部分,因此編譯器可以更好地對(duì)它們進(jìn)行處理,而宏天生是與語(yǔ)言本身割裂開(kāi)來(lái)的,因此很難處理。更糟的是,與模板不同,宏可能展開(kāi)為在偶然情況下能夠編譯的“傳輸線(xiàn)噪音”。最后,宏中的錯(cuò)誤可能只有在宏展開(kāi)之后才能被報(bào)告出來(lái),而不是在定義時(shí)。

                 即使在極少的情況下,有正當(dāng)理由編寫(xiě)宏,也決不要考慮編寫(xiě)一個(gè)以常見(jiàn)詞或者縮略語(yǔ)為名字的宏。盡可能快的取消宏的定義(#undef)。

            示例:

                1、定義一個(gè)宏#define  min(n, m)    ((n) < (m) ? (n) : (m)) 

                        定義兩個(gè)變量a和b,min(++a, b) 傳入之后是這樣 ((++a) < (b) ? (++a) : (b))   如果++a小于b的話(huà),a就自加了兩次,很明顯不符合宏使用的初衷。

                2、將模板實(shí)例化轉(zhuǎn)給宏,宏僅能理解C語(yǔ)言的小括號(hào)和方括號(hào),并將其進(jìn)行匹配。然而,C++又定義了一個(gè)新的括號(hào)結(jié)構(gòu),即模板中使用的尖括號(hào)<和>。宏無(wú)法正確的匹配它們,這意味著在下面的宏調(diào)用中:

                   MACRO(Foo<int,double>)

                   宏會(huì)認(rèn)為傳給自己的是兩個(gè)參數(shù),即Foo<int和double>,而事實(shí)上該結(jié)構(gòu)是一個(gè)C++實(shí)體。

            例外情況:

                宏仍然是幾個(gè)重要任務(wù)的唯一解決方案,比如#include保護(hù)符,條件編譯中的#ifdef和#ifndef,以及assert的實(shí)現(xiàn)。

                在條件編譯中,要避免在代碼中到處雜亂地插入#ifdef。相反,應(yīng)該對(duì)代碼進(jìn)行組織,利用宏在驅(qū)動(dòng)一個(gè)公共接口的多個(gè)實(shí)現(xiàn),然后始終使用該接口。

                如果不想到處復(fù)制粘貼代碼段,那么可以使用宏,但要非常小心。
                   


                  來(lái)自:《C++編程規(guī)范》

            Feedback

            # re: 避免使用宏  回復(fù)  更多評(píng)論   

            2011-11-21 09:13 by yanxinmeng
            最近寫(xiě)的代碼 涉及到一些別人寫(xiě)的宏。 其中還有 臨時(shí)變量。。。

            # re: 避免使用宏  回復(fù)  更多評(píng)論   

            2011-11-21 16:04 by C小加
            使用的時(shí)候要注意,有時(shí)候會(huì)得到莫名其妙的答案,你還不知道該怎么改@yanxinmeng

            # re: 避免使用宏[未登錄](méi)  回復(fù)  更多評(píng)論   

            2011-12-07 08:48 by alex
            轉(zhuǎn)載請(qǐng)注明出處。

            這段話(huà) 引自 《C++編程規(guī)范101條規(guī)則、準(zhǔn)則最佳實(shí)踐》 書(shū)里面的第16條: 避免使用宏。

            很不認(rèn)同,轉(zhuǎn)載不標(biāo)明出處的。不尊重原作者,對(duì)讀者也不負(fù)責(zé)。

            # re: 避免使用宏  回復(fù)  更多評(píng)論   

            2012-03-04 12:04 by 泡菜
            規(guī)范是死的,人是活的!!

            舉個(gè)例子;不少書(shū)/規(guī)范主張不用goto...有空下個(gè)Linux內(nèi)核代碼看看,goto遍地都是!Linux內(nèi)核就是依靠goto一點(diǎn)一點(diǎn)把性能給壓榨出來(lái)的(至于是如何壓榨的自己想想,俺不解釋?zhuān)?br>
            不少主張不用goto的,有幾塊能達(dá)到寫(xiě)內(nèi)核的水平??

            # re: 避免使用宏  回復(fù)  更多評(píng)論   

            2012-03-04 13:28 by C小加
            聽(tīng)人說(shuō)搞嵌入式的用的不是循環(huán),是goto,呵呵。自從老師說(shuō)不要用goto,我就從來(lái)都沒(méi)用過(guò)。看來(lái)goto是提高效率的利器啊,可是危險(xiǎn)性就不用考慮么?疑惑@泡菜

            # re: 避免使用宏  回復(fù)  更多評(píng)論   

            2012-03-15 18:34 by coreBugZJ
            個(gè)人覺(jué)得,各種機(jī)制都是有其存在的價(jià)值,不必?fù)淄鬟^(guò)正。

            # re: 避免使用宏  回復(fù)  更多評(píng)論   

            2012-03-16 10:09 by C小加
            贊同。宏在嵌入式中宏也占很大比重。這只是對(duì)一些初學(xué)者來(lái)說(shuō)的,使用宏的時(shí)候一定要萬(wàn)分小心。
            @coreBugZJ

            只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久久久亚洲AV无码麻豆| 国产精品欧美久久久久无广告 | 伊人久久综合热线大杳蕉下载| 精品久久久久久国产| 久久天天日天天操综合伊人av| 亚洲精品无码久久毛片 | 久久亚洲AV成人无码国产| 久久免费的精品国产V∧| 久久精品国产精品亜洲毛片| 色天使久久综合网天天| 久久99国产乱子伦精品免费| 欧美一级久久久久久久大片| 无码精品久久久久久人妻中字 | 中文字幕乱码人妻无码久久| 久久香蕉一级毛片| 青草国产精品久久久久久| 国产亚洲色婷婷久久99精品91 | 18岁日韩内射颜射午夜久久成人| 久久精品视频免费| 亚洲中文久久精品无码ww16| 久久国产精品免费一区| 久久香蕉一级毛片| 99久久中文字幕| 国产精品免费福利久久| 亚洲中文久久精品无码| 亚洲一级Av无码毛片久久精品| 久久亚洲国产精品一区二区| 97久久精品国产精品青草| 亚洲av伊人久久综合密臀性色| 欧美久久一级内射wwwwww.| 国产一区二区精品久久凹凸| 国产L精品国产亚洲区久久| 国产精品久久国产精麻豆99网站| 无码人妻少妇久久中文字幕蜜桃| 久久99热这里只有精品国产| 久久青青草视频| 日韩久久无码免费毛片软件| 污污内射久久一区二区欧美日韩 | 99久久免费国产精品特黄| 久久亚洲国产精品123区| 日日狠狠久久偷偷色综合96蜜桃 |