轉自:http://zhidao.baidu.com/link?url=JLCaxBAXLJVcx_8jsyJVF92E_bZjo4ONJ5Ab-HGlNBc1dfzcAyFAIygwP1qr18aaMA_a1gTjCNV5yhhJ4YnBTLjSXqY1rSKk2v1p8pUP8K_
轉自:http://blog.csdn.net/cabinriver/article/details/8960119
今天跟蹤一段開源代碼的時候,因為對代碼不太熟悉,所以要打印一些關鍵的信息。便順手整理了一下這個能打印文件名、行號、函數名的宏。
1、打印文件名、行號、函數的兩種方式
- /**************************************************************************
- * @Copyright (c) 2013, ChenMH, All rights reserved.
- * @file : main.cpp
- * @version : ver 1.0
- * @author : ChenMH
- * @date : 2013/05/22 14:07
- * @brief : 打印文件名、行號、函數名的方法。
- **************************************************************************/
- #include <cstdio>
- //定義打印宏,並在打印信息前加入文件名、行號、函數名
- //此宏展開后,類似於printf("123"),printf("456");
- #define TRACE_CMH_1 (printf("%s(%d)-<%s>: ",__FILE__, __LINE__, __FUNCTION__), printf)
- //此宏展開后,類似於printf("%d""%d", 1, 2);
- #define TRACE_CMH_2(fmt,...) \
- printf("%s(%d)-<%s>: "##fmt, __FILE__, __LINE__, __FUNCTION__, ##__VA_ARGS__)
- //注:由於第一個宏TRACE_CMH_1調用了兩次printf,所以效率沒有第二個宏高。
- //如果編譯器支持C99標准的話,可以用第二個宏。
- int count = 1;
- class CBase
- {
- public:
- CBase()
- {
- //打印當前行所在文件、行號、函數,以及其它信息。
- TRACE_CMH_2("BASE: [%d]\n", count++);
- }
- };
- class CSub : public CBase
- {
- public:
- CSub()
- {
- //打印當前行所在文件、行號、函數,以及其它信息。
- TRACE_CMH_1("SUB: [%d]\n", count++);
- }
- };
- int main(int argc, char **argv)
- {
- CSub sub;
- return 0;
- }
2、在項目中使用
- /********************************************************
- * @author : ChenMH
- * @date : 2013/05/24 10:11
- * @brief : 定義調試打印宏
- ********************************************************/
- #define _DEBUG_TRACE_CMH_ 2
- #if 0 != _DEBUG_TRACE_CMH_
- #include <cstdio>
- #endif
- #if 1==_DEBUG_TRACE_CMH_ //普通打印
- #define TRACE_CMH printf
- #elif 2==_DEBUG_TRACE_CMH_ //打印文件名、行號
- #define TRACE_CMH(fmt,...) \
- printf("%s(%d): "##fmt, __FILE__, __LINE__, ##__VA_ARGS__)
- #elif 3==_DEBUG_TRACE_CMH_ //打印文件名、行號、函數名
- #define TRACE_CMH(fmt,...) \
- printf("%s(%d)-<%s>: "##fmt, __FILE__, __LINE__, __FUNCTION__, ##__VA_ARGS__)
- #else
- #define TRACE_CMH
- #endif //_TRACE_CMH_DEBUG_
- /*******************************************************/
這段代碼中用到了這幾個宏:
1) __VA_ARGS__ 是一個可變參數的宏,這個可宏是新的C99規范中新增的,目前似乎gcc和VC6.0之后的都支持(VC6.0的編譯器不支持)。宏前面加上##的作用在於,當可變參數的個數為0時,這里的##起到把前面多余的","去掉的作用。
2) __FILE__ 宏在預編譯時會替換成當前的源文件名
3) __LINE__ 宏在預編譯時會替換成當前的行號
4) __FUNCTION__ 宏在預編譯時會替換成當前的函數名稱