C++20模板lambas的限制和使用

max*_*x66 7 c++ lambda language-lawyer generic-lambda c++20

C++ 标准专家的几个相关问题。

传入的 C++20引入了模板 lambdas ( P0428R2 )。

所以代替

auto x = [](auto x, auto y){ return x+y; };
Run Code Online (Sandbox Code Playgroud)

我们可以指定模板参数如下

auto x = []<typename T>(T x, T y){ return x+y; };
Run Code Online (Sandbox Code Playgroud)

到现在为止还挺好。

第一个问题:模板 lambda 中的显式模板参数是否只能从参数中推导出来,或者是否可以添加非推导出的模板参数?

阅读 P0428r1 我没有看到任何明确的限制,但是,我也没有看到非推导模板参数的例子。

在第一个近似值中,我认为非推导的模板参数是合法的,因为我看到以下愚蠢的代码

int main()
 {   
   []<int = 0>(){ }();
 }
Run Code Online (Sandbox Code Playgroud)

使用 g++(10.0.0 head)和 clang++(10.0.0 head)编译和运行。

假设允许非推导的模板参数,第二个问题是:如何在提供模板参数的同时调用模板 lambda?

举例:给定以下模板 lambda

auto x = []<std::size_t I>(auto t){ return std::get<I>(t); };
Run Code Online (Sandbox Code Playgroud)

I没有显式命名的情况下调用此类 lambda 时,是否有一些语法用于指定模板参数operator()

我试过

x<0u>(y);
Run Code Online (Sandbox Code Playgroud)

<被解释为关系运算符。

我试过简单地添加 template

x template <0u>(y);
Run Code Online (Sandbox Code Playgroud)

但它不起作用。

Nic*_*las 6

lambda 函数中的模板头没有特殊限制。毕竟,Lambda 只是您可以在任何operator()过载情况下做的事情的简写。

在调用operator()lambda 函数时,没有用于提供模板参数的特殊语法。如果您有未推导的模板参数,则必须使用传统机制来提供这些模板参数。伊:lamb.operator()<Args>(...)

  • 您的意思是像“x.operator()&lt;0&gt;()”之类的东西吗? (3认同)