模板基类成员出现g++编译器错误
g++ compiler error with templated base class member
我正在尝试使用g++编译一些Microsoft Visual C++代码。现在我遇到了一个编译器错误,我真的无法理解。(简化的)代码如下:
template<int X> struct A {
template<class Ret> static Ret call() {
return 0;
}
};
template<int X> struct B : A<X> {
int f() {
return A<X>::call<int>();
}
};
当我试图用g++(版本4.4.5)编译它时,我得到了以下错误:
main.cpp: In member function int B<X>::f():
main.cpp:16: error: expected primary-expression before int
main.cpp:16: error: expected ; before int
main.cpp:16: error: expected unqualified-id before > token
如果我从方法A::调用中删除模板类型(Ret),代码编译得很好。有人能看到这里出了什么问题吗?
谢谢!
您需要template
关键字:
return A<X>::template call<int>();
call
是一个依赖名称,这意味着它的含义取决于一个模板参数,而当编译器处理f()
时,这个参数是未知的。您需要通过在call
前面加上template
关键字来指示它是一个函数模板。
当您尝试访问嵌套类型时也会发生同样的事情:您需要添加typename
关键字来指示名称表示类型:
template <typename T>
struct A { typedef int type; };
template <typename T>
void f()
{
typename A<T>::type i = 0; // notice "typename" here
}
有时你甚至需要混合两者:
template <typename T>
struct A
{
template <typename U>
struct inner { };
};
template <typename T>
void f()
{
typename A<T>::template inner<int> var;
}
这两个关键词的使用在这个问题的答案中得到了充分的解释:我必须把"模板"answers"typename"关键词放在哪里以及为什么?(感谢@Björn Pollex找到链接)。
A
是一个模板,在不知道X
的情况下,编译器无法确定A<X>
的内容。尤其是它不知道call
最终会成为一个模板。
要告诉编译器,您必须使用template
关键字:
template<int X> struct B : A<X> {
int f() {
return A<X>::template call<int>();
}
};
您必须指定您调用的函数是一个模板,因为它是模板类的一部分。编译器不知道任何给定的A<X>
都有一个名为call
的模板函数,因此您需要帮助它
template<int X> struct B : A<X> {
int f() {
return A<X>::template call<int>();
}
};
相关文章:
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么所有C++编译器都会崩溃或挂起此代码
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 我收到同义重复编译器错误。我应该如何修复"类型"X"的参数与类型"X"的参数不兼容?
- 为什么C++编译器没有检测到正确声明的类?