CRTP和过载返回类型推导
CRTP and overload return type deduction
考虑以下代码:
template <class Crtp>
struct Base
{
const float& get(const short int i) const {return std::get<0>(tuple);}
const double& get(const int i) const {return std::get<1>(tuple);}
const long double& get(const unsigned long long int i) const {return std::get<2>(tuple);}
std::tuple<float, double, long double> tuple;
};
struct Derived
: public Base<Derived>
{
template <class... Misc, class Return = /*SOMETHING*/>
const Return& test(Misc&&... misc) const
{return this->get(std::forward<Misc>(misc)...);}
};
这是一个示例代码:它没有说明有用的东西,例如,可以使用auto函数声明来解决问题。我知道这一点,并且我不会搜索关于这个特定示例的变通方法。
我的问题是:/*SOMETHING*/
是什么,才能根据传递的Misc
类型获得get
的正确重载的返回类型?
只需将decltype
与std::declval
(来自<type_traits>
)一起使用即可:
class Return = decltype(std::declval<Derived const>().get(std::declval<Misc>()...))
相关文章:
- 如何获取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++) 不允许模板返回类型和函数名称之间有空格?
- 从具有泛型返回类型的 crtp 基类调用派生类中的函数
- CRTP:如何推断要用作返回类型的成员类型?
- std::d eclval vs crtp,无法从不完整类型推断方法返回类型
- 使用派生的模板参数类型作为函数 (CRTP) 的返回类型
- 推断CRTP中模板化成员函数的返回类型
- 具有基类的CRTP试图获取派生类成员的返回类型:不完整类型的使用无效
- CRTP和过载返回类型推导