一、什么是继承
继承机制是面向对象程序设计使代码可以复用的重要手段,它允许程序员在保持原有类特性的基础上进行扩展,增加功能。产生的新类,称为派生类。
继承定义的格式:class Deriveclassname:acess-lable BaseClassName
Deriveclassname:派生类的类名 acess-lable :继承类型,分为private,public,protected BaseClassName:基类名
二、三种继承方式
1、public继承:基类的public成员在派生类中仍为public,基类的protected成员在派生类中仍为protected,基类的private不可见。
1、protected继承:基类的public成员在派生类中为protected,基类的protected成员在派生类中仍为protected,基类的private不可见。
1、private继承:基类的public成员在派生类中为private,基类的protected成员在派生类中为private,基类的private不可见。
#include<iostream>
using namespace std;
class Base
{
public:
int _pub;
protected:
int _pro;
private:
int _pri;
public:
void print()
{
_pub = 0;
_pro = 1;
_pri = 2;
cout << "_pub:" << _pub << endl;
cout << "_pro:" << _pro << endl;
cout << "_pri:" << _pri << endl;
}
Base()
{
cout << "Base:()" << endl;
}
};
class Derived :public Base//public继承,对于Base类的成员变量的属性不变
{
public:
int _pubD;
protected:
int _proD;
private:
int _priD;
public:
void printD()
{
_pub = 3;
_pro = 4;
_pri = 5;//此处错误,Base类的私有成员不可访问
cout << "_pub:" << _pub << endl;
cout << "_pro:" << _pro << endl;
}
Derived()
{
cout << "Derived:()" << endl;
}
};
三、继承关系中构造函数和析构函数的调用关系
Derived d;
先调用派生类的构造函数->在初始化列表中调用基类的构造函数->执行基类的构造函数的函数体->执行派生类的构造函数的函数体
先调用派生类的析构函数->执行派生类的析构函数的函数体->在最后一条语句处转去执行基类的析构函数
说明:
1. 基类没有缺省构造函数,派生类必须要在初始化列表中显式给出基类名和参数列表。
2. 基类没有定义构造函数,则派生类也无需定义,全部使用缺省构造函数。
3. 基类定义了带有形参表构造函数,派生类就一定定义构造函数。
四、继承体系的作用域
1.继承体系中基类和派生类是两个不同的作用域
2.若子类和父类中有同名成员,子类将屏蔽父类对成员的直接访问
3.子类对象可以赋值给父类对象,反之则不能
4.父类的指针或引用可以指向子类对象,反之则不能
5.友元关系不能继承,即:基类的友元不能访问子类的私有和保护成员
6.基类若定义了static成员,则整个继承体系中只能有一个static成员实例
五、关于单继承,多继承和菱形继承的模型
1.单继承
//单继承
class B
{
public:
int _pub;
};
class D1 :public B
{
public:
int _pubD1;
};
2.多继承
//多继承
class B
{
public:
int _pub;
};
class D1 :public B
{
public:
int _pubD1;
};
class D2 :public B
{
public:
int _pubD2;
};
3.菱形继承
//菱形继承
class B
{
public:
int _pub;
};
class D1 :public B
{
public:
int _pubD1;
};
class D2 :public B
{
public:
int _pubD2;
};
class D3 :public D1, public D2
{
public:
int _pubD3;
};
六、虚拟继承
sizeof(D1)=12,可知比普通的单继承多了四个字节,它的存储方式如下所示:此外,虚拟菱形继承还解决了二义性问题。
//虚拟继承
class B
{
public:
int _pub;
};
class D1 : virtual public B
{
public:
int _pubD1;
};