admin管理员组文章数量:1794759
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++打印类名+函数名的方法 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1686492909a73640.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论