首页 > 后端开发 > C++ > 正文

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

穿越時空
发布: 2025-12-01 12:56:02
原创
439人浏览过
使用__FILE__和__LINE__宏可打印文件名与行号,结合__func__封装成DEBUG_LOG宏便于调试输出,并可通过条件编译控制输出,提升问题定位效率。

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

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

使用 __FILE__ 和 __LINE__ 宏

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

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

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

#include <iostream>
<p>void debug_log() {
std::cout << "File: " << <strong>FILE</strong> << ", Line: " << <strong>LINE</strong> << std::endl;
}</p><p>int main() {
debug_log();
return 0;
}</p>
登录后复制

输出可能类似于:

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

Cowriter
Cowriter

AI 作家,帮助加速和激发你的创意写作

Cowriter 107
查看详情 Cowriter
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的使用的详细内容,更多请关注php中文网其它相关文章!

全能打印神器
全能打印神器

全能打印神器是一款非常好用的打印软件,可以在电脑、手机、平板电脑等设备上使用。支持无线打印和云打印,操作非常简单,使用起来也非常方便,有需要的小伙伴快来保存下载体验吧!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号