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__

你可能感兴趣的:(C++语法)