第十三章 类继承
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;}
};