概述
在输出调试信息的时候,经常会用到这几个宏。首先看一段示例代码,再来介绍这几个宏:
#include <stdlib.h>
#include <stdio.h>
//替换函数名
#ifndef _DEBUG
#define LOGFUNC(...) ((void)0)
#else
#define LOGFUNC(...) (printf(__VA_ARGS__))
#endif
//宏前面加上##的作用在于:当可变参数的个数为0时,这里的## 起到把前面多余的","去掉的作用
#define DEBUG_INFO(format, ...) printf("File:%s, Line:%d, Function:%s, %s",
__FILE__, __LINE__ , __FUNCTION__, ##__VA_ARGS__);
void show_debug_info()
{
DEBUG_INFO("%s", "hello world");
}
int main()
{
LOGFUNC("%sn", "this is test");
show_debug_info();
system("pause");
return 0;
}
1) __VA_ARGS__ 是一个可变参数的宏,总体来说就是将左边宏中 ... 的内容原样抄写在右边 __VA_ARGS__ 所在的位置。
2) __FILE__ 宏在预编译时会替换成当前的源文件名
3) __LINE__ 宏在预编译时会替换成当前的行号
4) __FUNCTION__ 宏在预编译时会替换成当前的函数名称
5)类似的宏还有__DATE__, __TIME__,__STDC__, __TIMESTAMP__等,可以当作一个变量来使用。
关于宏##的有关解析,在另一篇文章有介绍:http://blog.csdn.net/hellokandy/article/details/50592971
上述代码中定义的DEBUG_INFO宏,就是输出控制台的调试信息。比如说,我们通过 OutputDebugString 输出调试信息这样写:
#ifdef _DEBUG
#define OUTPUT_DEBUGW(fmt, ...) PrintDebugStringW(_T(__FILE__),__LINE__, fmt, __VA_ARGS__)
#else
#define OUTPUT_DEBUGW ((void)0)
#endif
void PrintDebugStringW(const wchar_t *file, int lineno, const wchar_t *pszFmt, ...)
{
va_list vlArgs = NULL;
va_start(vlArgs, pszFmt);
size_t nLen = _vscwprintf(pszFmt, vlArgs) + 1;
wchar_t *strBuffer = new wchar_t[nLen];
_vsnwprintf_s(strBuffer, nLen, nLen, pszFmt, vlArgs);
va_end(vlArgs);
//OutputDebugStringW(strBuffer);
wchar_t buf[4096];
swprintf_s(buf, 4096, L"%s<%d>: tid[%d] :t%sn", file, lineno, GetCurrentThreadId(), strBuffer);
OutputDebugStringW(buf);
delete [] strBuffer;
}
最后
以上就是热情唇膏为你收集整理的C++ 输出代码所在的文件、行数以及函数名称的全部内容,希望文章能够帮你解决C++ 输出代码所在的文件、行数以及函数名称所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复