如何在模板函数中以lambda作为参数推断函数类型参数
How to infer a function type parameter in a template function with a lambda passed as argument?
考虑以下内容:
#include <utility>
#include <string>
template<typename>
class C;
template<typename R, typename T>
class C<R(&)(T)> {
public:
template<typename F>
C(F&& fun) {}
};
template<typename T>
C<T> makeC(T&& fun) {
return C<T>(std::forward<T>(fun));
}
int foo(int a){return a;}
int main() {
auto p1 = makeC(foo); // OK
auto p2 = C<int(&)(int)>([](int a){return a;}); // OK
// auto p3 = makeC([](int a){return a;}); // FAIL
}
实例示例
p3
的声明失败,因为编译器无法从通过参数传递的lambda中推断int(&)(int)
的类型。p1
是可以的,因为可以从函数foo
轻松地推断该类型,并且p2
是可以的,因为该类型已明确声明。
它失败了:
error: invalid use of incomplete type 'class C<main()::<lambda(int)> >'
有什么方法可以使编译器纠正地推断函数类型,给定lambda?
P.S。:C 17答案也可以,如果适用。
实际问题是lambda函数具有自己的类型,不能简化为 R(&)(T)
。因此,C<T>
是编译器正确概述的不完整类型。
只要您使用非捕捉lambdas,就可以依靠它们衰减来发挥指针并执行此操作的事实:
auto p3 = makeC(*(+[](int a){return a;}));
或以下:
template<typename T>
auto makeC(T&& fun) -> C<decltype(*(+std::forward<T>(fun)))> {
return C<decltype(*(+std::forward<T>(fun)))>(std::forward<T>(fun));
}
与捕获Lambdas一起使用的另一个可能的解决方案是:
#include <utility>
#include <string>
template<typename T>
class C: T {
template<typename F>
C(F&& fun): T{std::forward<F>(fun)} {}
};
template<typename R, typename T>
class C<R(&)(T)> {
public:
template<typename F>
C(F&& fun) {}
};
template<typename T>
C<T> makeC(T&& fun) {
return C<T>(std::forward<T>(fun));
}
int foo(int a){return a;}
int main() {
auto p1 = makeC(foo);
auto p2 = C<int(&)(int)>([](int a){return a;});
auto p3 = makeC([](int a){return a;});
}
这样,在处理lambda时,C
实际上从中继承了其operator()
。
相关文章:
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- C++中的高效循环缓冲区,它将被传递给C样式数组函数参数
- 当从函数参数中的临时值调用复制构造函数时
- 如何从"decltype()"获取函数参数的数量<funtion>?
- 如何将lambda作为模板类的成员函数参数
- 模板参数推导失败,函数参数/参数不匹配
- 如何在C++中将迭代器作为函数参数传递
- 将函数参数"const char*"转换为"std::string_view"是
- C++ 如何将数组值解压缩为函数参数
- 主函数参数的属性
- 具有两个间接寻址运算符 (C++) 的函数参数的用途
- "Warning: Comma within array index expression"但逗号分隔函数参数
- 如何定义在用作函数参数时工作的类模板的转换
- 将函数参数完美转发到函数指针:按值传递呢?
- 为什么我不能将引用作为 std::async 的函数参数传递
- 什么..(省略号)作为函数原型中唯一的函数参数,C++?
- 是否可以就地构造一个固定大小的数组作为函数参数?
- 接受模板作为函数参数
- 将成员函数作为构造函数参数调用时出错 "Variable is not a type name"
- Arduino 函数参数