本文作者为C++初学者,学习之中难免有误,该文章仅为参考
面向对象概述
继承:改变类之间的关系
多态:让基类的pointer或refence得以十分透明的指向基类的某个派生对象
继承
继承发生在对象与对象之间,通常由一个基类所派生出来
假设现有Libmat类和从Libmat中继承出的Book类
现有
void load_check_in(Libmat &mat)
{
// mat 实际上代表由Libmat派生出来的的对象,如Book, Files
mat.check_in();
if (mat.is_late())
mat.access_fine();
if(mat.wating_list())
mat.notify_available();
}
假设程序中并没有Libmat对象,而只有其派生对象那么check_in
该如何解释,在程序运行过程中调用的到底是Libmat的check_in
还是Book的check_in
?,此实程序被决议(resloved)
为解决上述问题引入动态绑定(Dynamic binding)机制,虚拟函数实现动态绑定,通过在成员函数前添加 __virtual__关键字即可构建出一个虚拟函数
class Libmat{
public:
virtual void check_in() const{
cout << "This is a Libmat";
}
}
class Book : public Libmat{
public:
void check_in() const {
cout << "This is a Book";
}
}
将基类中的check_in
设置为虚拟函数, 则在派生类中定义的同名函数前可不加 virtual,默认情况下编译器会在静态编译时完成决议,但引入虚拟函数之后,决议将会发生在动态编译时,将根据调用check_in
的对象的具体类型来调用相应的函数。
也可以将这种行为理解为覆盖,在基类中的check_in
函数在Book类调用时,被Book类的check_in
函数覆盖,如果还想使用Libmat类的check_in
函数,可以通过添加Libmat::
(class scope修饰符)来指定决议结果。
其中继承过来的成员函数,与派生类的成员函数无需区分,他们的使用并无显著差异
在公开继承(public Inheritance)的情况下,基类的public member同样提供给派生类来使用,基类的protected同样也称为派生类的protected,也提供给派生类使用,但基类的private完全不提供给派生类使用,
private 对象只能够被该对象的成员函数调用,除此之外都不能被调用,直接调用也不可以。
根据一般规则凡基类中定义有一个或多个虚拟函数应该要将其destructor 声明为virtual
初始化派生类时必须初始化基类