模板类内模板类的函数返回类型
Function return type for template class inside template class
我正在使用 c++ 模板并在模板类中创建了一个模板类。
情况是这样的:
template <typename T>
class C {
public:
class N {
T v;
};
template <typename D>
N *fun(D d);
};
template <typename T>
template <typename D>
N *C<T>::fun(D d) {
}
int main() {
C<int> obj;
obj.fun('c');
}
现在编译器给出的错误是:
main.cpp:14:1: 错误:"N"未命名类型
如果我在类外使用函数原型作为C<T>::N *C<T>::fun(D d)
,编译器给出错误:
main.cpp:14:1:错误:在"C::N"之前需要"typename",因为"C"是依赖范围
如果我在类中定义定义,那么它可以正常工作。但是我不想让它内联,我该怎么办?
正如编译错误所建议的那样,请使用typename
template <typename T>
template <typename D>
typename C<T>::N *C<T>::fun(D d) {
}
作为替代方法,您可以使用尾随返回类型:
template <typename T>
template <typename D>
auto C<T>::fun(D d) -> N*
{
return nullptr;
}
相关文章:
- 如何获取std::result_of函数的返回类型
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- C++ 这里有一个返回 (24) 的布尔返回类型函数
- 使用SFINAE来检测void返回类型函数的存在
- 模板返回类型函数如何在C++中工作
- 如何在返回类型函数模板的专用化中使用派生类型?( "couldn't infer template argument" )
- Bon appetit :从 int 返回类型函数在 main() 中打印字符串
- 在引用或指针返回类型函数上输入
- 在后面的返回类型函数语法中,auto关键字背后是否有意图
- 我可以在c++中重写字符串返回类型函数吗?