第十三章 类继承

13.1.1派生一个类

     1,派生类对象存储了基类的数据成员

     2,派生类对象可以使用基类的方法。

     3,派生类需要自己的构造函数。  

     4,派生类可以根据需要添加额外的数据成员和成员函数。

13.1.12构造函数:访问权限的考虑

     1,派生类不能直接访问基类的私有成员,而必须通过基类方法进行访问。

     2,派生类构造函数必须使用基类构造函数。

     3,创建派生类对象时,程序首先创建基类对象。

     4,释放对象的顺序与创建对象的顺序相反,即首先执行派生类的析构函数,然后自动调用基类的析构函数。

13.2派生类和基类之间的特殊关系

     1,派生类对象可以使用基类的方法,条件是方法不是私有的。

     2,基类指针可以在不进行显式类型转换的情况下指向派生类对象;基类引用可以在不进行显式类型转换的情况下引用派生类对象;

     3,基类指针或引用只能用于调用基类方法。

     4,通常C++ 要求引用和指针类型与赋给的类型匹配,但这一规则对继承来说却是例外。

13.3继承——is-a关系

     1,继承的三种方法:公有继承,私有继承,保护继承。

     2,公有继承是最常用的方式,建立一种is-a关系,即派生类对象也是一个基类对象,可以对基类对象执行的任何操作,也可以对派生类对象执行。

13.4多态公有继承

     1,多态公有继承:在派生类中重新定义基类方法,使用虚方法。

     2,为何需要虚构析构函数
         使用delete释放由new分配的对象的代码。

#include"stdio.h"
#include"string.h"
#include"algorithm"
using namespace std;

class Brass{
private:
    enum {MAX = 35};
    char fullName[MAX];
    long acctNum;
    double balance;
public:
    Brass(const char *s = "Nullbody",long an = -1,double bal = 0.0);
    void Deposit(double amt);
    virtual void Withdraw(double amt);
    ///virtual 关键字至关重要,使用了:程序将根据引用或指针指向的对象的类型来选择方法
    ///未使用,则程序将根据引用类型或指针的类型来选择方法。(派生类和基类重载了方法)
    double Balance()const;
    virtual void ViewAcct()const;
    virtual ~Brass(){}
};
///Brasss plus Account Class
class BrassPlus: public Brass{
private:
    double maxLoan;
    double rate;
    double owerBank;
public:
    BrassPlus(const char *s = "Nullbody",long an = -1,double bal = 0.0,double m1 = 500,double r = 0.10);
    BrassPlus(const Brass & ba,double m1 = 500,double r = 0.1);
    virtual void ViewAcct()const;
    virtual void Withdraw(double amt);
    void ResetMax(double m){maxLoan = m;}
    void ResetRate(double r){rate = r;}
    void ResetOwes(){owesBank = 0;}
};