在 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中文网其他相关文章!