C++打印类名+函数名的方法

C++打印类名+函数名的方法

打log的时候经常需要将输出log时所在的类名,函数名写清楚。
但是自己敲函数名和类名比较麻烦,复制粘贴的时候也会忘记修改而出错。
下面介绍下如何在G++/GCC编译器下获得函数名和类名:

如果只想获得函数名可以用C99的特性:

__func__

但是在成员函数中,想打出 类名::函数名 这样的log,用上面这个宏就做不到了。
在GCC下可以利用GCC的一个扩展特性来做到,就是这货:

__PRETTY_FUNCTION__

它能以字符串的形式返回完整的函数签名,包括返回值、类名、函数名、参数列表、模板参数。具体功能可以自己搜索。

但是这样还是不够,打log的时候我们只需要函数头,参数列表、模板参数没有用。这个简单:

static std::string _CutParenthesesNTail(std::string&& prettyFuncon)
{
    auto pos = prettyFuncon.find('(');
    if(pos!=std::string::npos)
        prettyFuncon.erase(prettyFuncon.begin()+pos, prettyFuncon.end());

    return std::move(prettyFuncon);
}
#define __STR_FUNCTION__ _CutParenthesesNTail(std::string(__PRETTY_FUNCTION__))

在函数里调用_ _ STR_FUNCTION _ _这个宏就能得到函数头了。
它去掉了括号开始后面的所有内容,只保留返回值、类名、函数名。

还可以添加上空格和冒号之类的东西:

// means function name + parentheses (P = parentheses)
#define __STR_FUNCTIONP__ __STR_FUNCTION__+"()"

// means function name + parentheses + colon (C = colon)
#define __STR_FUNCTIONPC__ __STR_FUNCTION__+"(): "

// means the head of one piece of log.
#define LOG_HEAD __STR_FUNCTIONPC__
  • 6
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值