引入继承的目的:①派生类继承了基类的成员,实现了原有代码的重用。②实现代码的扩充,只有在派生类中通过添加新的成员,加入新的功能,类的派生才有实际意义。
基类的构造函数和析构函数不能被继承,在派生类中,如果对派生类新增的成员进行初始化,就需要加入派生类的构造函数,同时,对所有从基类继承下来的成员的初始化工作,还是由基类的构造函数完成
1、派生类构造函数和析构函数的执行顺序
通常,当创建派生类对象时,首先执行基类的构造函数,随后执行派生类的构造函数;当撤销派生类对象时,则先执行派生类的析构函数,随后再执行基类的析构函数。析构函数的调用顺序与构造函数的调用顺序正好相反。
2、派生类构造函数和析构函数的构造规则
(1)简单的派生类的构造函数
在C++中,派生类构造函数的一般格式为:
派生类名(参数总表):基类名(参数表){
派生类新增数据成员的初始化语句
}
- 其中,基类构造函数的参数,通常来源于派生类构造函数的参数总表,也可以用常数值,因为这里是调用基类构造函数,所以这些参数是实参不是形参,它们可以是派生类构造函数总参数表中的参数,也可以是常量和全局变量。
- 当基类的构造函数没有参数,或没有显式定义构造函数时,派生类可以不向基类传递参数,甚至可以不定义构造函数。
- 派生类不能继承基类中的构造函数和析构函数。当基类含有带参数的构造函数时,派生类必须定义构造函数,以提供把参数传递给基类构造函数的途径。
例 1:当基类含有带参数的构造函数,派生类构造函数的构造方法。
#include<iostream>
#include<string>
using namespace std;
class Student{
//声明类 Student
protected:
int number; //学号
string name; //姓名
float score; //成绩
public:
Student(int num1,string name1,float score1){
// 基类构造函数
number=num1;
name=name1;
score=score1;
}
void print(){
cout<<"number:"<<number<<endl;
cout<<"name:"<<name<<endl;
cout<<"score:"<<score<<endl;
}
};
class Ustudent:public Student{
//声明公有派生类 Student
private:
string major;
public:
Ustudent(int num1,string name1,float score1,string major1):