使用__LINE__、__FILE__和__func__可获取行号、文件路径和函数名,结合__PRETTY_FUNCTION__显示完整函数签名,通过宏封装实现跨平台日志输出。

在C++中获取当前函数名和行号,常用于调试、日志记录或异常追踪。虽然C++标准没有直接提供反射机制来获取函数名,但借助编译器内置宏和预定义标识符,可以轻松实现。
C++标准支持几个预定义的标识符和宏,可以在任何函数中直接使用:
示例:
<font face="Courier New"><strong>void</strong> testFunction() {
std::cout << "File: " << __FILE__ << std::endl;
std::cout << "Line: " << __LINE__ << std::endl;
std::cout << "Function: " << __func__ << std::endl;
}</font>输出类似:
立即学习“C++免费学习笔记(深入)”;
File: /path/to/main.cpp Line: 10 Function: testFunction
在GCC和Clang中,__PRETTY_FUNCTION__ 提供完整的函数原型,包括返回类型、参数等。
示例:
<font face="Courier New"><strong>template</strong><<strong>typename</strong> T>
<strong>void</strong> process(T value) {
std::cout << __PRETTY_FUNCTION__ << std::endl;
}</font>输出可能是:
void process(T) [with T = int]
比__func__ 更详细,适合模板调试。
为了方便使用,可以定义一个日志宏:
<font face="Courier New">#define LOG_DEBUG() \
std::cout << "[" << __FILE__ << ":" << __LINE__ \
<< "] " << __func__ << " called.\n"</font>调用方式:
<font face="Courier New">LOG_DEBUG(); // 自动打印文件、行号和函数名</font>
在发布版本中可通过条件编译关闭:
<font face="Courier New">#ifdef DEBUG
# define LOG_DEBUG() ...
#else
# define LOG_DEBUG() do {} while(0)
#endif</font>基本上就这些。利用__func__、__LINE__和编译器扩展,就能高效获取调试信息,不复杂但容易忽略细节。不同编译器对__PRETTY_FUNCTION__的支持略有差异,建议结合文档使用。
以上就是c++++怎么获取当前函数名和行号_c++中获取函数调试信息的方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号