
在C++中获取当前函数名,可以使用内置的预定义标识符 __func__。它不是传统意义上的宏,而是一个由编译器自动生成的静态字符串,用于表示当前函数的名称。__func__ 在 C++11 及以后版本中被正式支持,使用方便且无需包含额外头文件。
__func__ 的基本用法__func__ 是一个隐式定义的局部静态常量字符串,存在于每个函数作用域内,其类型为 const char*,值为当前函数的名称(不包含命名空间或类名)。
示例代码:
void myFunction() {
std::cout << "当前函数名: " << __func__ << std::endl;
}
struct MyClass {
void doSomething() {
std::cout << "当前函数名: " << __func__ << std::endl;
}
};
输出结果:
当前函数名: myFunction 当前函数名: doSomething与其他调试信息结合使用
__func__ 常与 __FILE__ 和 __LINE__ 配合,在日志或调试输出中提供上下文信息。
HyperWrite
AI写作助手帮助你创作内容更自信
54
查看详情
#include <iostream>
void debugLog() {
std::cout << "[" << __FILE__ << ":" << __LINE__
<< "] 函数 " << __func__
<< " 被调用" << std::endl;
}
这种组合有助于快速定位问题发生的位置。
注意事项和限制
尽管 __func__ 使用简单,但需注意以下几点:
- __func__ 不是宏,不能用于宏替换上下文中动态展开函数名,除非配合其他技巧(如宏包装)。
- 它只返回函数的“原始名称”,不包含类名、命名空间或参数类型(即无修饰名)。
- 在内联函数中,__func__ 显示的是该内联函数本身的名称,但在多个调用点展开时仍保持一致。
- 在匿名函数(如 lambda)中,__func__ 返回类似 operator() 的通用名称,无法区分具体 lambda 实例。
为了简化日志输出,可将 __func__ 封装进调试宏:
#define LOG_DEBUG() \
std::cout << "[" << __FILE__ << ":" << __LINE__ \
<< "] " << __func__ << "() 正在执行..." << std::endl
void example() {
LOG_DEBUG(); // 自动打印文件、行号和函数名
}
这种方式提升代码整洁度,便于统一管理调试信息。
基本上就这些。__func__ 是一个轻量、标准、安全的方式获取函数名,适合用于调试、日志记录等场景,不需要引入复杂机制。只要确保编译器支持 C++11 或更高标准即可正常使用。
以上就是c++++中如何获取当前函数名_预定义宏__func__使用指南的详细内容,更多请关注知识资源分享宝库其它相关文章!
相关标签: c++ ios 作用域 常量 命名空间 封装 标识符 const 字符串 char Lambda operator 作用域 大家都在看: c++中什么是模板_C++模板编程泛型机制详解 c++如何连接两个字符串_c++字符串拼接操作全攻略 c++中如何使用map_c++ map关联容器使用指南 c++如何判断map中是否存在某个键_c++ map键值存在性检查方法 c++中什么是虚函数_virtual虚函数与多态实现原理解析






发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。