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

            天下

            記錄修行的印記

            調試技巧:可變參數宏

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





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

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

            void printf(const char* format, …);

            直到最近,可變參數表還是只能應用在真正的函數中,不能使用在宏中。

            C99編譯器標準終于改變了這種局面,它允許你可以定義可變參數宏(variadic macros),這樣你就可以使用擁有可以變化的參數表的宏。可變參數宏就像下面這個樣子:

            #define debug(…) printf(__VA_ARGS__)

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

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

            而處理器會把宏的調用替換成:

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

            因為debug()是一個可變參數宏,你能在每一次調用中傳遞不同數目的參數:

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

            可變參數宏不被ANSI/ISO C++ 所正式支持。因此,你應當檢查你的編譯器,看它是否支持這項技術。

            VC:使用可變參數宏

            VC6是不支持可變參數宏的,VC2005支持。

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

            其中,__VA_ARGS__就是不定參數。

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


            補充:改一下。CTL_CommonLogger::Output是一個類的靜態成員函數。

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

            #define PRINT(x, ...)    \

            Print(x, __VA_ARGS__);

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

            不定參數函數的實現,可以參考Windows的TRACE宏或ATLTRACE宏。

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

            評論

            # re: 調試技巧:可變參數宏 2013-11-28 09:19 丁智勇

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

            # re: 調試技巧:可變參數宏 2014-03-12 14:07 luo

            好  回復  更多評論   

            <2012年3月>
            26272829123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            国产69精品久久久久久人妻精品| 成人资源影音先锋久久资源网| 色天使久久综合网天天| 麻豆精品久久久久久久99蜜桃| 国产精品美女久久久久| 欧美激情精品久久久久久久九九九| 久久精品国产久精国产一老狼| 国产成人精品久久一区二区三区av| 国产69精品久久久久观看软件| 久久香蕉综合色一综合色88| 久久精品国产亚洲AV不卡| 国产呻吟久久久久久久92| 久久国产精品成人片免费| 综合久久一区二区三区| 国产成人精品久久综合| 久久精品亚洲中文字幕无码麻豆| 欧美一区二区久久精品| 久久久久久毛片免费看| 国产成人久久777777| 99re这里只有精品热久久| 亚洲国产精品无码久久| 久久这里有精品| 污污内射久久一区二区欧美日韩| 香蕉久久一区二区不卡无毒影院| 久久亚洲精精品中文字幕| 亚洲午夜久久久久久久久电影网| 午夜精品久久久内射近拍高清 | 一本大道久久东京热无码AV | 久久亚洲私人国产精品| 国产成人无码精品久久久性色| 久久久精品日本一区二区三区 | 亚洲精品乱码久久久久久久久久久久| 日日狠狠久久偷偷色综合96蜜桃 | 亚洲综合伊人久久大杳蕉| 超级碰碰碰碰97久久久久| 怡红院日本一道日本久久 | 久久久久亚洲爆乳少妇无| 国产福利电影一区二区三区久久老子无码午夜伦不 | 97久久久久人妻精品专区 | 一极黄色视频久久网站| 国产精品久久久久久五月尺|