std::source_location可获取文件名、行号、列号和函数名;通过默认参数std::source_location::current()在编译时自动捕获调用点信息,简化日志函数定义与调用,避免手动传递__FILE__、__LINE__等宏,提升代码简洁性与可靠性。

在 C++20 中,std::source_location 提供了一种轻量且标准的方式来获取代码调用点的元信息,比如文件名、行号、函数名等。这使得日志记录更加简洁高效,无需手动传入 __FILE__、__LINE__ 等宏。
std::source_location 能获取哪些信息?
std::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获取调用点信息的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1487783.html
微信扫一扫
支付宝扫一扫