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

            天下

            記錄修行的印記

            調(diào)試技巧:可變參數(shù)宏

            如果不用可變參數(shù)宏
            最簡單的方法:
            #ifdef     _DEBUG
                #define DebugMsg printf
            #else
                
            #define DebugMsg //printf
            #endif





            在 GNU C 中,宏可以接受可變數(shù)目的參數(shù),就象函數(shù)一樣,例如:
            #define pr_debug(fmt,arg...) \
            printk(KERN_DEBUG fmt,##arg)

            用可變參數(shù)宏(variadic macros)傳遞可變參數(shù)表
            你可能很熟悉在函數(shù)中使用可變參數(shù)表,如:

            void printf(const char* format, …);

            直到最近,可變參數(shù)表還是只能應(yīng)用在真正的函數(shù)中,不能使用在宏中。

            C99編譯器標(biāo)準(zhǔn)終于改變了這種局面,它允許你可以定義可變參數(shù)宏(variadic macros),這樣你就可以使用擁有可以變化的參數(shù)表的宏??勺儏?shù)宏就像下面這個樣子:

            #define debug(…) printf(__VA_ARGS__)

            缺省號代表一個可以變化的參數(shù)表。使用保留名 __VA_ARGS__ 把參數(shù)傳遞給宏。當(dāng)宏的調(diào)用展開時,實(shí)際的參數(shù)就傳遞給 printf()了。例如:

            Debug(“Y = %d\n”, y);

            而處理器會把宏的調(diào)用替換成:

            printf(“Y = %d\n”, y);

            因?yàn)閐ebug()是一個可變參數(shù)宏,你能在每一次調(diào)用中傳遞不同數(shù)目的參數(shù):

            debug(“test”); //一個參數(shù)

            可變參數(shù)宏不被ANSI/ISO C++ 所正式支持。因此,你應(yīng)當(dāng)檢查你的編譯器,看它是否支持這項(xiàng)技術(shù)。

            VC:使用可變參數(shù)宏

            VC6是不支持可變參數(shù)宏的,VC2005支持。

            使用如下:
            #define TRACE(pszFormat, ...) \
             CTL_CommonLogger::Output(LOGGER, LEVEL_TRACE, pszFormat, __VA_ARGS__);

            其中,__VA_ARGS__就是不定參數(shù)。

            注意:直接這樣,是沒法編譯通過的,因?yàn)檫@個宏要求編譯器是VC2002(VC7.0)以上的版本,也就是說,_MSC_VER宏應(yīng)該是1400以上的值。所以,使用前,應(yīng)該加上如下的定義:
            #ifndef _MSC_VER  
            #define _MSC_VER 1600
            #endif      
                    1600也就是VC8.0。


            補(bǔ)充:改一下。CTL_CommonLogger::Output是一個類的靜態(tài)成員函數(shù)。

            類似,可以使用下面的寫法:

            #define PRINT(x, ...)    \

            Print(x, __VA_ARGS__);

            Print函數(shù)的原型:int Print(char * x, ...);

            不定參數(shù)函數(shù)的實(shí)現(xiàn),可以參考Windows的TRACE宏或ATLTRACE宏。

            posted on 2011-06-26 10:38 天下 閱讀(2636) 評論(2)  編輯 收藏 引用 所屬分類: C/C++

            評論

            # re: 調(diào)試技巧:可變參數(shù)宏 2013-11-28 09:19 丁智勇

            寫的很好,用到了。謝謝!  回復(fù)  更多評論   

            # re: 調(diào)試技巧:可變參數(shù)宏 2014-03-12 14:07 luo

            好  回復(fù)  更多評論   

            <2011年6月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            欧美日韩中文字幕久久久不卡| 亚洲精品乱码久久久久久自慰| 97热久久免费频精品99| 91精品国产高清久久久久久io | 久久亚洲国产精品五月天婷| 欧美精品一区二区久久| 99久久香蕉国产线看观香| 午夜人妻久久久久久久久| 夜夜亚洲天天久久| 国产美女亚洲精品久久久综合| 久久久精品免费国产四虎| 亚洲国产精品综合久久网络 | 日韩人妻无码一区二区三区久久| 国内精品九九久久久精品| 久久久久亚洲?V成人无码| 热re99久久精品国99热| 久久精品一区二区三区中文字幕| 亚洲AV乱码久久精品蜜桃| 国产精品成人久久久久三级午夜电影| 久久久SS麻豆欧美国产日韩| 久久99精品久久久久久秒播| 久久精品人人做人人妻人人玩| 伊人色综合久久天天网| 国产激情久久久久影院| 久久久久亚洲AV片无码下载蜜桃| 久久经典免费视频| 久久婷婷五月综合97色直播| 伊人久久精品线影院| 久久精品午夜一区二区福利| 一本一本久久A久久综合精品| 亚洲国产日韩欧美久久| 久久天天躁狠狠躁夜夜av浪潮 | 久久996热精品xxxx| 久久久91精品国产一区二区三区| 精品国产乱码久久久久久1区2区| 久久久久久精品免费免费自慰| 久久精品国产福利国产琪琪| 久久综合中文字幕| 国产激情久久久久影院老熟女免费| 久久亚洲精品中文字幕三区| 国产精品一久久香蕉国产线看|