我的基本理解是没有纯虚函数的实现,然而,我被告知可能有纯虚函数的实现。
class A {
public:
virtual void f() = 0;
};
void A::f() {
cout<<"Test"<<endl;
}
上面的代码可以吗?
让它成为一个带有实现的纯虚函数的目的是什么?
我的基本理解是没有纯虚函数的实现,然而,我被告知可能有纯虚函数的实现。
class A {
public:
virtual void f() = 0;
};
void A::f() {
cout<<"Test"<<endl;
}
上面的代码可以吗?
让它成为一个带有实现的纯虚函数的目的是什么?
当前回答
你必须给一个纯虚析构函数一个主体,例如:)
阅读:http://cplusplus.co.il/2009/08/22/pure-virtual-destructor/
(链接中断,使用存档)
其他回答
它的优点是它强制派生类型仍然重写方法,但也提供了默认的或添加的实现。
是的,这是正确的。在您的示例中,派生自A的类继承了接口f()和默认实现。但是你强迫派生类实现方法f()(即使它只是调用A提供的默认实现)。
Scott Meyers在Effective c++ (2nd Edition)第36项中讨论了这一点,区分接口的继承和实现的继承。项目编号可能在最新版本中发生了变化。
如果您有应该由派生类执行的代码,但不希望它直接执行——并且希望强制重写它。
您的代码是正确的,尽管总的来说这不是一个经常使用的特性,而且通常只在试图定义纯虚析构函数时才会看到——在这种情况下,您必须提供一个实现。有趣的是,一旦从该类派生出来,就不需要重写析构函数了。
因此,纯虚函数的一个合理用法是将纯虚析构函数指定为“非final”关键字。
下面的代码是惊人的正确:
class Base {
public:
virtual ~Base() = 0;
};
Base::~Base() {}
class Derived : public Base {};
int main() {
// Base b; -- compile error
Derived d;
}
你必须给一个纯虚析构函数一个主体,例如:)
阅读:http://cplusplus.co.il/2009/08/22/pure-virtual-destructor/
(链接中断,使用存档)
如果我问你动物的声音是什么,正确的回答是问哪种动物,这正是纯虚函数或抽象函数的目的,当你不能在基类(animal)中提供函数的实现,但每个动物都有自己的声音。
class Animal
{
public:
virtual void sound() = 0;
}
class Dog : public Animal
{
public:
void sound()
{
std::cout << "Meo Meo";
}
}