新闻中心

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

2025-12-01
浏览次数:
返回列表
使用__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>

输出可能类似于:

File: main.cpp, Line: 7

封装成调试宏更方便

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

ChatGPT Writer ChatGPT Writer

免费 Chrome 扩展程序,使用 ChatGPT AI 生成电子邮件和消息。

ChatGPT Writer 106 查看详情 ChatGPT Writer
#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的使用的详细内容,更多请关注其它相关文章!


# c++  # 建设图纸网站查询网址  # 查网站关键词排名查询  # seo关键词排名还选火18星  # 中文网  # 相关文章  # 数独  # 你可以  # 这一  # 几个  # 的是  # 如何实现  # 如何用  # 行号  # c++开发  # stream  # ios  # ai  # 网站怎么优化立联火3星  # 秀山县独立站seo优化  # 湖州seo优化推荐  # 盐城企业网站建设介绍  # 勉县抖音短视频seo  # 橙子建站网站优化  # 西城网络网站推广 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 手机CPU怎么影响游戏体验_手机CPU对游戏性能的影响分析  Mac怎么查看崩溃日志_Mac控制台错误报告分析  斑马英语APP如何开启夜间护眼阅读_斑马英语APP夜间模式与低蓝光设置教程  NRF24L01数据传输深度解析:解决大载荷接收异常与分包策略  在Runstone环境中高效处理TasteDive API的JSON数据  动漫岛观看全网网 动漫岛在线正版动漫入口  Shopware订单对象中获取产品自定义字段的正确方法  整合Supabase认证与Django模型:跨模式迁移的解决方案  12306选座系统怎么选连座_12306选座多人连坐操作方法  印象笔记如何设提醒任务防漏执行_印象笔记设提醒任务防漏执行【任务提醒】  J*aScript设计模式实践_j*ascript代码优化  怎样在Excel中做仪表盘_Excel仪表盘设计与关键指标展示方法  在J*aScript中复现SciPy的B样条拟合与求值:关键考量  C++如何比较两个字符串_C++ string compare函数与操作符对比  Go语言中的*string:深入理解字符串指针  “音游” × “怪文书” 题材的节奏冒险游戏 《晕晕电波症候群》确定于2026年4月发售!  如何将一个大型PHP应用拆分为多个Composer包_微服务与模块化架构的Composer实践  Discord Slash 命令响应超时问题的异步解决方案  微博网页版主页入口 微博官方网站免登录访问  sublime怎么格式化代码_sublime代码美化与一键排版插件配置  Lar*el的路由模型绑定怎么用_Lar*el Route Model Binding简化控制器逻辑  腾讯视频怎么举报不良内容_腾讯视频内容举报流程与违规信息处理方法  Yandex搜索引擎官方地址 俄罗斯网络世界的主要入口  魅族17怎样用浏览器译外语网页_iPhone魅族17浏览器译外语网页【即时翻译】  美团外卖商家服务中心入口 美团商家版官网入口  解决Tabulator日期时间排序问题的专业指南  漫蛙漫画网页端入口 漫蛙2官方正版漫画站点  黑猫投诉统一入口官网 消费者权益保护投诉平台  如何解决电商平台定制报价请求的“黑洞”问题,SprykerQuoteRequest模块助你提升客户体验与销售效率  windows10怎么关闭系统提示音_windows10彻底静音设置方法  Python字典中优雅地迭代剩余元素的方法  12306几点到几点不能订票? | 官方最新系统维护时间全解析  Golang如何使用net/url解析URL_Golang URL解析与处理方法  使用Python高效删除Word宏并转换DOCM为DOCX格式  怎么在浏览器上运行HTML文件_浏览器运行HTML文件技巧【技巧】  新手怎么开始学化妆 零基础化妆入门教程  外媒分析《GTA6》定价:卖100美元可以但真没必要!  Log4j Console Appender性能瓶颈与高并发优化策略  如何使用spryker/configurable-bundles-products-resource-relationship模块解决复杂产品捆绑关系难题  谷歌推RCS信息存档功能:公司可监控员工私密信息!  Composer的 "check-platform-reqs" 命令有什么用_在部署前检查生产环境是否满足Composer依赖需求  cad如何更改注释性对象的比例_cad注释性比例调整方法  如何为你的Composer包编写自动化测试_集成PHPUnit到Composer的scripts工作流  PHP高效扁平化嵌套数组:使用array_merge与数组解包操作符  C++如何使用AddressSanitizer(ASan)_C++调试工具中检测内存访问错误的利器  Lar*el Excel导入时生成自定义递增ID的策略与实践  向日葵客户端怎么进行远程CentOS控制_向日葵客户端远程CentOS控制操作教程  漫蛙漫画官方主页入口 漫蛙MANWA网页直达访问链接  J*a里如何实现线程安全的懒加载单例_懒加载单例实现方法解析  零跑汽车11月交付量达70327台 实现连续9个月正增长 

搜索