函数返回类型中的模板类型推断
Template type deduction in function return type
这是
在成员变量和函数参数的模板类型推导中发布的问题的延续
我的.h文件包含以下行。
#include <iostream>
#include <complex>
#include <typeinfo>
template <typename T>
class MyClass
{
template <typename T0>
struct myTypeTraits
{ using type = T0; };
template <typename T0>
struct myTypeTraits<std::complex<T0>>
{ using type = T0; };
public:
using T0 = typename myTypeTraits<T>::type;
void setVar1(const T0& v);
void setVar2(const T& v);
T0 getVar1() const;
T getVar2() const;
void print() const;
T0 var1;
T var2;
};
.cpp文件具有以下代码。
#include "tmp.h"
template <class T>
void MyClass<T>::setVar1(const T0& v)
{
var1 = v;
}
template <class T>
void MyClass<T>::setVar2(const T& v)
{
var2 = v;
}
template <class T>
T0 MyClass<T>::getVar1() const
{
return var1;
}
template <class T>
T MyClass<T>::getVar2() const
{
return var2;
}
template <typename T>
void MyClass<T>::print() const
{
std::cout<<"var1: "<<var1<<std::endl;
std::cout<<"var2: "<<var2<<std::endl;
}
int main()
{
MyClass<float> tmp;
MyClass<std::complex<float> > tmp1;
tmp.print();
tmp1.print();
return 0;
}
现在,当我使用 g++ 中的 C++ 11 支持编译代码时,出现以下错误。
tmp.cpp:17:1: error: ‘T0’ does not name a type
T0 MyClass<T>::getVar1() const
^
如何删除错误?
编译器
无法知道T0
是在MyClass<T>
中定义的。因此,您需要正确限定 reutrn 类型:
template <class T>
typename MyClass<T>::T0 MyClass<T>::getVar1() const {
return var1;
}
或者,您可以使用尾随返回类型,您也不需要限定该类型:
template <class T>
auto MyClass<T>::getVar1() const -> T0 {
return var1;
}
尝试使用
// ......................vvvvvvvvvvvvvvvvvvvvvvv
void MyClass<T>::setVar1(typename MyClass<T>::T0 const & v)
{
var1 = v;
}
getVar1()
也是如此
相关文章:
- 如何获取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:错误:未知方法返回类型:自定义类型
- 基于返回类型的转换和过载扣除
- 如何在模板参数中分离函数类型返回类型和参数