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 中提升调试效率的小利器。











