答案:在C++11及以上版本中,可通过内置标识符__func__获取当前函数名。__func__是函数作用域内的静态常量字符串,类型为const char*,仅含函数原始名称,不包含命名空间或类名。可与__FILE__和__LINE__结合用于日志输出,辅助调试定位。需注意其非宏特性,无法在宏中动态展开;在lambda中返回operator(),不区分实例。可通过宏封装提升日志可读性,如定义LOG_DEBUG()自动输出文件、行号与函数名。该方法轻量安全,无需额外头文件,适用于标准兼容的C++编译器。

在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__ 配合,在日志或调试输出中提供上下文信息。
#include这种组合有助于快速定位问题发生的位置。void debugLog() { std::cout << "[" << __FILE__ << ":" << __LINE__ << "] 函数 " << __func__ << " 被调用" << std::endl; }
注意事项和限制
尽管 __func__ 使用简单,但需注意以下几点:
立即学习“C++免费学习笔记(深入)”;
- __func__ 不是宏,不能用于宏替换上下文中动态展开函数名,除非配合其他技巧(如宏包装)。
- 它只返回函数的“原始名称”,不包含类名、命名空间或参数类型(即无修饰名)。
- 在内联函数中,__func__ 显示的是该内联函数本身的名称,但在多个调用点展开时仍保持一致。
- 在匿名函数(如 lambda)中,__func__ 返回类似 operator() 的通用名称,无法区分具体 lambda 实例。
扩展技巧:宏封装增强可读性
为了简化日志输出,可将 __func__ 封装进调试宏:
#define LOG_DEBUG() \
std::cout << "[" << __FILE__ << ":" << __LINE__ \
<< "] " << __func__ << "() 正在执行..." << std::endl
void example() {
LOG_DEBUG(); // 自动打印文件、行号和函数名
}
这种方式提升代码整洁度,便于统一管理调试信息。
基本上就这些。__func__ 是一个轻量、标准、安全的方式获取函数名,适合用于调试、日志记录等场景,不需要引入复杂机制。只要确保编译器支持 C++11 或更高标准即可正常使用。











