一、实验目的
O掌握派生类的声明方法和派生类构造函数的定义方法
O掌握不同方式下,基类成员在派生类中的访问属性和访问规则
二、实验内容
输入下列程序:
#include <iostream>
using namespace std;
class Base {
public:
void setx(int i)
{
x = i;
}
int getx()
{
return x;
}
public:
int x;
};
class Derived :public Base {
public:
void sety(int i)
{
y = i;
}
int gety()
{
return y;
}
void show()
{
cout << "Base::x=" << x << endl;
}
public:
int y;
};
int main()
{
Derived bb;
bb.setx(16);
bb.sety(25);
bb.show();
cout << "Base::x=" << bb.x << endl;
cout << "Derived::y=" << bb.y << endl;
cout << "Base::x=" << bb.getx() << endl;
cout << "Derived::y=" << bb.gety() << endl;
return 0;
}
程序运行结果:
结果分析:
类 Derived 由类 Base 公有派生出来,所以类 Base 中的成员函数setx() 和 成员变量x在公有派生类中仍是公有成员。因此,它们可以被派生类的对象 obj 访问。
将基类Base中数据成员x的访问权限改为private时,会出现的错误:
原因:基类的私有成员变量x,派生类成员函数show()不可直接访问,派生类对象也不能访问。
将基类Base中数据成员x的访问权限改为protected时,会出现的错误:
原因:基类的保护成员变量x在派生类中为保护成员,派生类对象不能访问。
在源程序基础上,将派生类Derived的继承方式改为private时,会出现的错误:
原因:基类的公有成员变量x和函数setx()在派生类中为私有成员,派生类对象不能访问。
在源程序基础上,将派生类Derived的继承方式改为protected时,会出现的错误:
原因:基类的公有成员变量x和函数setx()在派生类中为保护成员,派生类对象不能访问。
由此延伸出派生类对基类成员的访问规则:
(1) 私有继承和保护继承的访问规则
(2)公有继承的访问规则
基类成员在派生类中的访问属性
(1) 基类中的私有成员
无论哪种继承方式,基类中的私有成员不允许派生类继承,即在派生类中是不可直接访问的。
(2) 基类中的公有成员
当类的继承方式为公有继承时,基类中的所有公有成员在派生类中仍以公有成员的身份出现。
当类的继承方式为私有继承时,基类中的所有公有成员在派生类中都以私有成员的身份出现。
当类的继承方式为保护继承时,基类中的所有公有成员在派生类中都以保护成员的身份出现。
(3) 基类中的保护成员
当类的继承方式为公有继承时,基类中的所有保护成员在派生类中仍以保护成员的身份出现。
当类的继承方式为私有继承时,基类中的所有保护成员在派生类中都以私有成员的身份出现。
当类的继承方式为保护继承时,基类中的所有保护成员在派生类中仍以保护成员的身份出现。
三、实验总结
(1)继承是面向对象程序设计的一个重要特性,它允许在已有类的基础上创建新的类,新类可以从一个或多个已有类中继承函数和数据,而且可以重新定义或加进新的数据和函数,从而形成类的层次或等级。
(2)从以上实验结果得知。派生的属性受到继承的方式的影响,派生的属性是具有从严特性的。无论是派生类对象还是成员函数对其进行访问都应遵循一定规则。
标签:继承,成员,派生类,公有,访问,基类 来源: https://blog.csdn.net/weixin_47045219/article/details/121707695
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。