基类的构造函数和析构函数不能被继承,在派生类中,如果对派生类新增的成员进行初始化,需要加入派生类的构造函数
下面定义了一个基类 base_class1 和一个派生类 deived_class
#pragma once
#include <iostream>
using namespace std;
//基类,包括一个public成员price,一个protected成员discount
class base_class1
{
public:
base_class1(double price_)
{
price = price_;
}
~base_class1() = default;
double show_price()
{
return price*discount;
}
double price = 0;
protected:
double discount = 1;
};
//派生类
class deived_class :public base_class1
{
public:
deived_class(double price_) :base_class1(price_){};//派生类的构造需要用到基类的构造函数
void over_discount(double discount_)
{
discount = discount_;
}
void output()//显示派生类的值
{
cout << discount << endl;
cout << price << endl;
}
};
那么创建派生类程序 如下:
base_class1 base(90.0);
cout << base.show_price() << endl;
deived_class deived(80.0);
deived.output();
deived.over_discount(0.8);
deived.output();
cout << base.show_price() << endl;// 输出基类的price, 等于价格乘以折扣
运行结果如下:
90 //基类的price
1 //派生类的
80
0.8
80
90 //基类的discount并未被改变
在派生类中使用基类的同名成员
使用之前加上基类名和作用域标识符“::”**
class X
{
public :
int f();
};
class Y:public X
{
public:
int f();
int g();
};
void Y::g()
{
f();//表示访问的是派生类中的f(),即调用Y::f();
X::f();//要访问基类中的f(),则如此表示
}
//派生类对象访问时
Y obj;
obj.f();
obj.X::f();//要访问基类中的f()