接触新项目的时候发现一个很奇怪的情况,输出栏里竟然有除了文件名之外的文字
搜索发现,原来是下面这行代码的功劳
#pragma message("需要处理xxx的功能")
#pragma message(messagestring)
是在编译期间,将文字串(messagestring)发送到标准输出窗口。
#pragma message在编译时报告和显示信息
outputdebugstr 在运行时显示信息 【这个试过没成功,有时间再看】
messagestring 参数可以将文字串常量扩展成一个宏,从而可以显示任何形式的字符串。
#pragma message( "Compiling " __FILE__ )
这样做是很方便了,但是还有局限。在标准输出窗口中可以看见#pragma message的输出信息,但是鼠标点右键弹出的上下文菜单中“Go to Error/Tag”菜单项是置灰的,不可用。
下面继续扩展,激活上下文菜单中“Go to Error/Tag”,从而定位到相应的代码行
定义头文件head.h
#define PTODO_LINENUMBER_TO_STRING(x) #x
#define PTODO_LINENUMBER(x) PTODO_LINENUMBER_TO_STRING(x)
#define INCLUDE_FILE_AND_LINE(string) __FILE__"(" PTODO_LINENUMBER(__LINE__) "): "string
其他文件引用head.h,使用方法如下
#pragma message( INCLUDE_FILE_AND_LINE("Compiling ") __FILE__ )