本文分别节选转自:
http://blog.csdn.net/w3031213101/article/details/5420486
http://www.cnblogs.com/fzhe/archive/2012/12/25/2832250.html
1.C++中的多态是通过虚函数实现的,即在函数的前面加virtual;虚函数的主要作用是通过基类访问派生类的东西。
virtual foo();
虚函数在基类中不用定义实现,虚函数在派生类中实现。
虚函数只能借助于指针或者引用来达到多态的效果。
前提B类继承与A类 且foo()为虚函数
void bar(A *a)
{
a->foo();//被调用的是A::foo()还是B::foo() ?
}
如果a指向的是A类的实例,则A::foo()被调用,如果a指向的是B类实例,则指向
B::foo();
在设计一个基类的时候,如果发现一个函数需要在派生类里有不同的表现,那么它就应该是虚的。
从设计角度讲,出现在基类中的虚函数是接口,出现在派生类中的虚函数是接口的具体实现。通过
这样的方法,就可以将对象的行为抽象化。
虚函数总是在派生类中被改写,这种改写被称为“override”。
override是指派生类重写基类的虚函数。重写的函数必须有一致的参数表和返回值(允许返回值不同)
纯虚函数不需要定义其实际操作,它的存在只是为了在派生类中被重新定义,只是为了提供一个多态接口。
只有拥有纯虚函数的类,就是一种抽象类,它是不能被实例化的。
virtual void foo()=0; //标志一个虚函数为纯虚函数 (=0)
补充:如果类B继承了A之后,A是抽象类,如果类B没有改写A中的纯虚函数,那么B本身也就成为一个拥有纯虚函数
的类,也就变成抽象类了。
内联函数,构造函数,静态成员函数为什么不能为virtual函数?
重点虚函数是运行期间确定的
1 > 内联函数
内联函数是在编译时期展开,而虚函数的特性是运行时才动态联编,所以两者矛盾,不能定义内联函数为虚函数
2 > 构造函数
构造函数用来创建一个新的对象,而虚函数的运行是建立在对象的基础上,在构造函数执行时,对象尚未形成,所以不能将构造函数定义为虚函数
3 > 静态成员函数
静态成员函数属于一个类而非某一对象,没有this指针,它无法进行对象的判别
2.C++派生类
class MDS : public Dispatcher, private md_config_obs_t {
}
这里MDS是派生类,基类分别是Dispathcher和md_config_obs_t,分别通过pubblic、private方式继承。