[英]Scope of pure virtual functions during derived class destruction - In C++
[英]C++ pure virtual functions implementation in derived class
我有一个顶级API(基于抽象类),它由一个基本API(将由不同的顶级API 重用)组成。
class api_base {
public:
virtual int foo() = 0;
};
class api_top : public api_base {
public:
virtual int bar() = 0;
}
然后,我想为基本 API 提供一个基本实现:
class imp_base {
public:
int foo() { return 1; }
}
最后使用基本 API 中定义的函数的基本实现来实现顶级API:
class imp_top : public api_top, public imp_base {
public:
int bar() { return 1; }
}
当我实例化一个imp_top
类型的对象时,编译器说foo()
函数没有实现。 但事实并非如此,因为imp_top
派生自imp_base
,它确实实现了foo()
函数。
对此有何建议?
先感谢您。
完整的测试代码:
#include <stdio.h>
class api_base {
public:
virtual int foo() = 0;
};
class api_top : public api_base {
public:
virtual int bar() = 0;
};
class imp_base {
public:
int foo() { printf("foo from imp_base\n"); }
};
class imp_top : public api_top, public imp_base {
public:
int bar() { printf("bar from imp_top\n"); }
};
int main()
{
printf("Hello\n");
imp_top a;
a.bar();
a.foo();
return 1;
}
编译结果:
test.cpp:26:12: error: cannot declare variable ‘a’ to be of abstract type ‘imp_top’
imp_top a;
^
test.cpp:18:7: note: because the following virtual functions are pure within ‘imp_top’:
class imp_top : public api_top, public imp_base {
^
test.cpp:5:17: note: virtual int api_base::foo()
virtual int foo() = 0;
^
test.cpp:29:6: error: request for member ‘foo’ is ambiguous
a.foo();
^
test.cpp:15:9: note: candidates are: int imp_base::foo()
int foo() { printf("foo from imp_base\n"); }
^
test.cpp:5:17: note: virtual int api_base::foo()
virtual int foo() = 0;
首先在子类中重新定义函数时总是使用override
关键字。
第二次阅读虚拟继承。
以下工作:
class api_base {
public:
virtual int foo() = 0;
};
class api_top : public virtual api_base {
public:
virtual int bar() = 0;
};
class imp_base : public virtual api_base {
public:
int foo() override { printf("foo from imp_base\n"); return 0; }
};
class imp_top : public api_top, public imp_base {
public:
int bar() override { printf("bar from imp_top\n"); return 0; }
};
int main(){
imp_top a;
a.bar();
a.foo();
return 1;
}
您应该使用override
关键字,然后您会注意到您没有实现接口而是定义了一个全新的foo()
方法。
您需要通过虚拟继承从api_base
派生imp_base
和api_top
。
改变:
class api_top : public api_base
到class api_top : public virtual api_base
和:
class imp_base
到class imp_base : public virtual api_base
然后它起作用了。
要理解这一点,请参阅:虚拟继承。 是的(刚刚看到 Ext3h 的帖子),使用override
关键字。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.