今天对C++ 工程里面的类里面的方法进行重新命名,发现以前写的一些调试信息也不得不修改:
以前,函数名是直接手动写到代码里面的,现在要改还数名,也要同时修改调试语句,这工程量蛮大的,就像找个一劳永逸 的方法。
__PRETTY_FUNCTION __ 获取完整的函数头信息
void IPCoreConnect::IPCoreConfirmWrite(unsigned char *p, int k)
__func__ 或 __FUNCTION__ 获取函数名
IPCoreConfirmWrite
__FILE__ 获取文件的 获取源文件的相对路径和名字
/scr/main.cc
__LINE__ 获取该行代码在文件中的行号
现在原来的代码就可以改写成:
很方便。
如:
int main(int argc,char **argv)
{
cout<<"Running In Function main"<<endl;
}
以前,函数名是直接手动写到代码里面的,现在要改还数名,也要同时修改调试语句,这工程量蛮大的,就像找个一劳永逸 的方法。
__PRETTY_FUNCTION __ 获取完整的函数头信息
void IPCoreConnect::IPCoreConfirmWrite(unsigned char *p, int k)
__func__ 或 __FUNCTION__ 获取函数名
IPCoreConfirmWrite
__FILE__ 获取文件的 获取源文件的相对路径和名字
/scr/main.cc
__LINE__ 获取该行代码在文件中的行号
现在原来的代码就可以改写成:
#include <iostream>
using std::cout;
using std::endl;
int main(int argc, char *argv[])
{
cout << "head " << __PRETTY_FUNCTION__ << endl;
cout << "name" << __FUNCTION__ << endl;
cout << "file" << __FILE__ << endl;
cout << "line" << __LINE__ << endl;
return 0;
}
输出的结果是:
很方便。
其他的,可能还有很多,本人孤陋寡闻,忘达人赐教。
转自:http://hi.baidu.com/bgvqxkfreybevyd/item/e9613093ef8c99bb83d295e2