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

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()

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

如何简化日志输出?

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

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