纯虚类有以下特征:
含有一个纯虚函数的类,叫做纯虚类。纯虚类不可以定义对象。
我个人觉得这个说法应该就是把纯虚类的主要特点说明了:
1、只要有一个纯虚函数。就称为纯虚类。
所以如果子类没有实现纯虚函数,相当子类也有纯虚函数,所以子类也是纯虚类。
2、其他类的定义与使用方式都与一般的类差不多。大致有如下地方:
纯虚类可以有成员变量 (可以)
纯虚类可以有普通的成员函数(可以)
纯虚类可不可以有其他虚函数(可以)
纯虚类可不可以又带有参数的构造函数? (可以)
可不可以在纯虚类的派生类的构造函数中显式调用纯虚类的带参数构造函数(可以)
3、使用方式上:不可以定义一个对象。
下面是另外一篇文章中说的说法:(纯虚类也称为抽象类)
带有纯虚函数的类称为抽象类。抽象类是一种特殊的类,它是为了抽象和设计的目的而建立的,它处于继承层次结构的较上层(而不是绝对的上层,也有可能是中层,甚至底层?)。抽象类是不能定义对象的,在实际中为了强调一个类是抽象类,可将该类的构造函数(设置为protected)说明为保护的访问控制权限。
抽象类的主要作用是将有关的组织在一个继承层次结构中,由它来为它们提供一个公共的根(其实不一定是根),相关的子类是从这个根派生出来的。
抽象类刻画了一组子类的操作接口的通用语义,这些语义也传给子类。一般而言,抽象类只描述这组子类共同的操作接口,而完整的实现留给子类。
抽象类只能作为基类来使用(大多数情况是其他类的基类,但是抽象类本身也有可能是子类),其纯虚函数的实现由派生类给出。如果派生类没有重新定义纯虚函数,而派生类只是继承基类的纯虚函数,则这个派生类仍然还是一个抽象类。如果派生类中给出了基类纯虚函数的实现,则该派生类就不再是抽象类了,它是一个可以建立对象的具体类了。
4、纯虚类一般是做为接口使用(这里要好好看设计模式了)
#include<iostream>
#include<string>
#include<vector>
#include<algorithm>
usingnamespacestd;
classbase
{
protected:
base(){}
virtualvoid eat(conststringname) =0;
};
classdog:publicbase
{
public:
vector<string>m_food;
voideat(conststringname);
voidpush_back(conststringname);
};
voiddog::eat(conststringname)
{
vector<string>::iteratoriter=std::find(m_food.begin(),m_food.end(),name);
if (m_food.end() !=iter)
{
cout<<"Dog eat "<<*iter<<endl;
}
}
voiddog::push_back(conststringname)
{
if (m_food.end() ==std::find(m_food.begin(),m_food.end(),name))
{
m_food.push_back(name);
}
}
intmain(void)
{
dogd;
d.push_back("bone");
d.eat("bone");
return0;
}