Essential C++ 笔记-1

本文作者为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
初始化派生类时必须初始化基类

猜你喜欢

转载自www.cnblogs.com/sophomores/p/12327403.html