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

c++中的std::source_location如何简化日志_c++20获取调用点信息

下次还敢
发布: 2025-12-04 13:46:02
原创
985人浏览过
std::source_location可获取文件名、行号、列号和函数名;通过默认参数std::source_location::current()在编译时自动捕获调用点信息,简化日志函数定义与调用,避免手动传递__FILE__、__LINE__等宏,提升代码简洁性与可靠性。

c++中的std::source_location如何简化日志_c++20获取调用点信息

在 C++20 中,std::source_location 提供了一种轻量且标准的方式来获取代码调用点的元信息,比如文件名、行号、函数名等。这使得日志记录更加简洁高效,无需手动传入 __FILE____LINE__ 等宏。

std::source_location 能获取哪些信息?

std::source_location 是一个类,位于 <source_location></source_location> 头文件中。它可以在编译时捕获以下信息:

  • 文件名:通过 file_name()
  • 行号:通过 line()
  • 列号:通过 column()(通常支持有限)
  • 函数名:通过 function_name()

这些值在运行时是常量,由编译器在调用时自动填充。

如何简化日志输出?

传统日志可能需要这样写:

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

log("error", __FILE__, __LINE__, "something went wrong");

每次调用都要手动传入位置信息,容易遗漏或出错。使用 std::source_location 后,可以自动捕获:

定义一个日志函数:

#include iostream>
#include
#include

void log(std::string_view message,
std::source_location loc = std::source_location::current()) {
std::cout }

调用时完全无需额外参数:

void foo() {
log("debug info");
}
// 输出示例:
// main.cpp:10 (void foo()) debug info

关键优势和注意事项

使用 std::source_location::current() 作为默认参数,调用点信息在调用处自动“快照”,无需宏或模板展开。

  • 函数内直接使用,默认参数指向调用者的位置
  • 适用于自由函数、成员函数、lambda(若为默认参数)
  • 开销极小,所有数据在编译期确定
  • 注意:不能用于非静态成员变量的默认参数,仅限函数参数

基本上就这些。用 std::source_location 写日志,既干净又可靠,是 C++20 中提升调试效率的小利器。

以上就是c++++中的std::source_location如何简化日志_c++20获取调用点信息的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源: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号