c++20的std::source_location是什么_c++获取源代码信息的标准方法

std::source_location可获取文件名、行号、列号和函数名,通过默认参数捕获调用位置,提供类型安全的日志与调试支持,取代传统宏,需C++20及现代编译器支持。

c++20的std::source_location是什么_c++获取源代码信息的标准方法

std::source_location 是 C++20 引入的一个轻量级工具,用于在运行时获取源代码中的位置信息,比如文件名、行号、函数名和列号。它属于头文件 ,是标准化的获取调用上下文位置的方式,取代了过去依赖宏如 __FILE____LINE__ 等的手动写法。

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

通过 std::source_location,你可以访问以下信息:

文件路径(file_name):源文件的完整或相对路径。 行号(line):当前所在的行号,从 1 开始计数。 列号(column):当前所在的列号,通常从 1 开始(部分编译器可能不支持,返回 0)。 函数名(function_name):所在函数的名称,通常是经过修饰的字符串(mangled name),但可读性比宏定义强。

如何使用 std::source_location?

最常见的用法是作为函数参数,默认捕获调用点的位置。由于其构造函数被声明为 consteval,它在编译期就能确定值,不会带来运行时性能开销。

示例代码:

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

#include #include void log(const std::string& msg,         const std::source_location& loc = std::source_location::current()){    std::cout << "文件: " << loc.file_name() << "n"              << "行号: " << loc.line() << "n"              << "函数: " << loc.function_name() << "n"              << "消息: " << msg << "nn";}void foo() {    log("进入 foo 函数");}int main() {    log("程序开始");    foo();    return 0;}

输出会显示每次调用 log 时的实际文件、行号和函数名,无需手动传入 __FILE__ 或 __LINE__。

与传统宏相比的优势

过去我们常这样写日志:

#define LOG(msg)     std::cout << "文件:" << __FILE__ << " 行:" << __LINE__ << " " << msg << "n"

这种方式虽然有效,但存在几个问题:

作用域复杂,容易出错。 不能作为普通函数参数传递,类型不安全。 函数名需要额外使用 __func__,且不在标准统一结构中。

而 std::source_location 提供了类型安全、可组合、更清晰的接口。它能嵌入到类、模板、函数参数中,适合现代 C++ 编程习惯。

注意事项和兼容性

尽管功能强大,但使用时需注意:

需要编译器支持 C++20,GCC 10+、Clang 10+、MSVC 19.29+ 基本可用。 column() 可能不被所有编译器支持,返回值可能是 0。 function_name() 返回的是编译器生成的函数签名,可能包含模板信息,较长但准确。 不要试图在非默认参数位置使用 .current(),会导致捕获错误的位置。

基本上就这些。std::source_location 是 C++20 中处理调试、日志、断言等场景下获取源码位置的标准方法,简洁、高效、类型安全,推荐替代传统的宏方式。

以上就是c++++20的std::source_location是什么_c++获取源代码信息的标准方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1487661.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 10:53:32
下一篇 2025年12月19日 10:53:47

相关推荐

发表回复

登录后才能评论
关注微信