
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__👁️ 阅读量:0
© 版权声明:本文《C++打印类名+函数名的方法》内容均为本站精心整理或网友自愿分享,如需转载请注明原文出处:https://www.zastudy.cn/wen/1686493126a269141.html。