通八洲科技

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

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

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

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

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

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

如何简化日志输出?

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

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() 作为默认参数,调用点信息在调用处自动“快照”,无需宏或模板展开。

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