C++ 获取当前正在执行的函数的相关信息

今天对C++ 工程里面的类里面的方法进行重新命名,发现以前写的一些调试信息也不得不修改:

如:

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值