HP-UX C/aC++编译器错误,使用纯虚拟方法的语句
HP-UX C/aC++ compiler bug with using-statements for pure virtual methods
我正试图使用HP C/aC++编译器版本A.03.85:在HP-UX 11.11中构建此合法的C++代码
class BaseClass
{
public:
virtual int sum(int i) = 0;
};
class Derived : public BaseClass
{
public:
using BaseClass::sum;
virtual int sum(int i1, int i2) = 0;
};
class Impl : public Derived
{
public:
virtual int sum(int i) { return i+1; }
virtual int sum(int i1, int i2) { return i1+i2; }
};
int main()
{
Derived * obj = new Impl;
obj->sum(5);
delete obj;
}
但是,由于以下编译错误,它失败了:
Error 181: "test_using.cpp", line 26 # Expected 2 argument(s) for "int Derived::sum(int,int)"; had 1 instead.
obj->sum(5);
^^^^^^^^^^^
我能够在Linux、AIX和Windows等其他平台上构建完全相同的代码,而不会出现任何问题。HP的问题似乎与纯虚拟方法有关,因为如果我从"BaseClass"中删除"=0"片段,那么一切都会按预期进行。
所以,我的问题是:你们以前也遇到过类似的问题吗?你是怎么解决的?这是一个已知的aC++错误吗?
请注意,我无法将纯虚拟方法转换为常规方法
class Derived : public BaseClass
{
public:
virtual int sum(int i) = 0;
virtual int sum(int i1, int i2) = 0;
};
或者,如果你想更好地记录你为什么进行了更改以及代码应该是什么:
class Derived : public BaseClass
{
public:
# ifdef USING_HP_BUGWARE
virtual int sum(int i) = 0;
# else
using BaseClass::sum;
# endif
virtual int sum(int i1, int i2) = 0;
};
相关文章:
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- CPP 继承虚拟方法解析顺序
- 我是否应该在包含虚拟方法的类上使用'memcpy'?如果没有,如何替换它?
- 用c++中的纯虚拟方法抽象模板类
- 解决虚拟方法的歧义继承的两种方法
- 没有针对完全专用模板类的外联虚拟方法定义