C++如何打印当前代码行号与文件名_C++预定义宏FILE与LINE的使用

使用__FILE__和__LINE__宏可打印文件名与行号,结合__func__封装成DEBUG_LOG宏便于调试输出,并可通过条件编译控制输出,提升问题定位效率。

c++如何打印当前代码行号与文件名_c++预定义宏file与line的使用

在C++开发中,调试信息对排查问题非常有帮助。打印当前代码所在的文件名和行号,能快速定位输出日志的来源位置。C++提供了预定义宏来实现这一功能,最常用的是 __FILE____LINE__

使用 __FILE__ 和 __LINE__ 宏

C++标准定义了几个有用的预定义宏:

__FILE__:在编译时被替换为当前源文件的完整路径(字符串)__LINE__:在编译时被替换为当前代码行的行号(整数)__func__:函数名(C++11起支持,不是宏,但常配合使用)

你可以像普通变量一样在代码中使用它们:

#include 

void debug_log() {std::cout << "File: " << FILE << ", Line: " << LINE << std::endl;}

int main() {debug_log();return 0;}

输出可能类似于:

立即学习“C++免费学习笔记(深入)”;

File: main.cpp, Line: 7

封装成调试宏更方便

为了便于频繁使用,通常将这些宏封装成一个调试输出宏:

#define DEBUG_LOG()     std::cout << "[" << __FILE__ << ":" << __LINE__ << "] " << __func__ << " called."

在代码中调用:

int main() {    DEBUG_LOG();    return 0;}

输出示例:

[main.cpp:15] main called.

注意事项与技巧

__FILE__ 包含完整路径时可能很长,可提取文件名部分(如通过 strrchr 找到最后一个 ‘/’ 或 ”)发布版本中可通过条件编译关闭调试输出:

#ifdef DEBUG# define DEBUG_LOG() std::cout << "[" << __FILE__ << ":" << __LINE__ << "]"#else# define DEBUG_LOG()#endif

现代C++还支持 __PRETTY_FUNCTION__(g++/clang)或 __FUNCSIG__(MSVC),提供更详细的函数签名信息

基本上就这些。利用好预定义宏,可以显著提升调试效率。不复杂但容易忽略细节。

以上就是C++如何打印当前代码行号与文件名_C++预定义宏FILE与LINE的使用的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1487188.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 10:28:23
下一篇 2025年12月19日 10:28:37

相关推荐

发表回复

登录后才能评论
关注微信