从参数的返回类型推断类型
Inferring type from argument's return type
我知道模板无法从赋值推断出类型,即
template <typename T>
T aFunction (int a) { /*...*/ }; // This obviously won't work
原因很明显。但这将起作用:
template <typename T>
T aFunction (T a, T b) { return a + b; }; // a-ok
"因为T
将从论点中推断出来。我想从中推断一下:
template <typename T>
T aFunction (std::function<T(int)> a) { return a(3);};
^
|
I specified it! ----------
因此,在使用时,函数应该做什么没有歧义:
std::function<double(int)> blah = [](int x){ return x / 2.0f; };
aFunction(blah);
唉,编译器不会和我合作:
没有匹配的成员函数来调用"aFunction">
忽略候选模板:不匹配 'function' against '(lambda at 文件.hpp:274:16)'
有没有办法做到这一点?,除了模板专业化(这是一个非常通用的类)或虚拟论点(我还没那么绝望)。
目录:
完全披露:以上只是对问题的简化,正是我需要的是:
template <typename T>
class MyStuff {
template <typename ReturnType>
MyStuff<ReturnType> aFunction(std::function<ReturnType(T)> a){
/*for each stuff in MyStuff do a(stuff)*/
}
}
其中MyStuff
包含类型T
的属性和一堆inline
函数,例如aFunction
。
如评论中所述,这有效:
#include <functional>
template <typename T>
struct MyStuff {
template <typename ReturnType>
MyStuff<ReturnType> aFunction(std::function<ReturnType(T)> a){
return {};
}
};
int main() {
MyStuff<int> stuff;
std::function<double(int)> fn = [](int) { return 0.; };
stuff.aFunction(fn);
}
相反,这不起作用:
int main() {
MyStuff<int> stuff;
stuff.aFunction([](int) { return 0.; });
}
错误是问题中发布的错误:
注意:候选模板被忽略:无法将"函数"与"(主.cpp:15:21的 lambda)"匹配
原因是类型推断仅适用于确切类型。不允许转换。在您的情况下,编译器应首先推断 lambda 的返回类型,然后以某种方式将其转换为std::function
,最后从使用 lambda 构造的返回类型中推断出函数的返回类型。
这不是类型推断的工作方式。
您可以使用如下方法解决它:
template <typename T>
struct MyStuff {
template <typename F>
auto aFunction(F &&f) -> MyStuff<decltype(std::forward<F>(f)(std::declval<T>()))> {
return {};
}
};
在科利鲁看到它。
相关文章:
- 如何获取std::result_of函数的返回类型
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 为什么返回类型中需要typename?C++
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 推导 std::vector::back() 的返回类型
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- QtQuick - qml:28:错误:未知方法返回类型:自定义类型
- 基于返回类型的转换和过载扣除
- 如何在模板参数中分离函数类型返回类型和参数