首页  >  文章  >  后端开发  >  如何在 C 20 中将 `std::source_location` 与可变参数模板函数一起使用?

如何在 C 20 中将 `std::source_location` 与可变参数模板函数一起使用?

DDD
DDD原创
2024-11-01 02:13:02885浏览

How to Use `std::source_location` with Variadic Template Functions in C  20?

解决可变参数模板函数中的源位置问题

在 C 20 中,使用 std::source_location 可以捕获函数调用上下文详细信息。然而,由于 source_location 参数的定位,将其与可变参数模板函数一起使用已被证明具有挑战性。

位置困境

可变参数总是位于末尾参数列表。由于以下原因,这阻碍了 std::source_location 的使用:

  • 第一次尝试:

    <code class="cpp">template <typename... Args>
    void debug(Args&&... args, const std::source_location& loc = std::source_location::current());</code>

    失败,因为可变参数必须

  • 第二次尝试:

    <code class="cpp">template <typename... Args>
    void debug(const std::source_location& loc = std::source_location::current(),
             Args&&... args);</code>

    插入意外参数时会给调用者带来歧义。

解决方案:拥抱推演指南

初始形式可以通过引入推演指南来焕发活力:

<code class="cpp">template <typename... Ts>
struct debug
{    
    debug(Ts&&... ts, const std::source_location& loc = std::source_location::current());
};

template <typename... Ts>
debug(Ts&&...) -> debug<Ts...>;</code>

这允许像这样的调用:

<code class="cpp">int main()
{
    debug(5, 'A', 3.14f, "foo");
}</code>

结论:

通过使用推导指南,C 程序员可以将 std::source_location 无缝地合并到可变参数模板函数中,以捕获函数调用上下文信息毫不费力。

以上是如何在 C 20 中将 `std::source_location` 与可变参数模板函数一起使用?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn