#include "stdafx.h"
#include <iostream>
#include <string> using namespace std; class CBase{
public:
CBase():Cb('A'),Ib(1),Db(1.0){}
void BTest(const CBase & btemp){
Cb=btemp.Cb;
Ib=btemp.Ib;//类内部,private成员可以访问,通过CBase类对象也可以访问private成员
Db=btemp.Db;//类内部,private成员可以访问,通过CBase类对象也可以访问protected成员
}
char Cb;
private:
int Ib;
protected:
double Db;
}; class CDerivative:public CBase
{
public:
CDerivative():CBase(),Cd('B'),Id(2),Dd(2.0){}
void DTest(const CDerivative & dtemp){
Cd=dtemp.Cd;
Id=dtemp.Id;//类内部,private成员可以访问,通过CBase类对象也可以访问private成员
Dd=dtemp.Dd;//类内部,private成员可以访问,通过CBase类对象也可以访问protected成员
}
char Cd;
private:
int Id;
protected:
double Dd; }; int _tmain(int argc, _TCHAR* argv[])
{
char c;
int i;
double d;
CBase base;
c=base.Cb;//类外部public声明成员可以访问
// i=base.Ib; //类外部private声明成员不可以访问
// d=base.Db;//类外部protected声明成员不可以访问 CDerivative derivative;
c=derivative.Cb;//类外部public声明成员可以访问
c=derivative.Cd;//类外部public声明成员可以访问
// i=derivative.Ib;//派生类中无法访问继承基类private成员
// i=derivative.Id;//类外部private声明成员不可以访问
// d=derivative.Db;//类外部protected声明成员不可以访问
// d=derivative.Dd;//类外部protected声明成员不可以访问 return 0;
}
第二:类的继承后方法属性变化。
使用private继承,父类的protected和public属性在子类中变为private;
使用protected继承,父类的protected和public属性在子类中变为protected;
使用public继承,父类中的protected和public属性不发生改变;
public继承 public protected 不可用
protected继承 protected protected 不可用
private继承 private private 不可用
protected继承和private继承能降低访问权限。
为了进一步理解三种不同的继续方式在其成员的可见性方面的区别,下面从三种不同角度进行讨论。
对于公有继续方式:
(1) 基类成员对其对象的可见性:
公有成员可见,其他不可见。这里保护成员同于私有成员。
(2) 基类成员对派生类的可见性:
公有成员和保护成员可见,而私有成员不可见。这里保护成员同于公有成员。
(3) 基类成员对派生类对象的可见性:
公有成员可见,其他成员不可见。
所以,在公有继续时,派生类的对象可以访问基类中的公有成员;派生类的成员函数可以访问基类中的公有成员和保护成员。这里,一定要区分清楚派生类的对象和派生类中的成员函数对基类的访问是不同的。
对于私有继续方式:
(1) 基类成员对其对象的可见性:
公有成员可见,其他成员不可见。
(2) 基类成员对派生类的可见性:
公有成员和保护成员是可见的,而私有成员是不可见的。
(3) 基类成员对派生类对象的可见性:
所有成员都是不可见的。
所以,在私有继续时,基类的成员只能由直接派生类访问,而无法再往下继续。
对于保护继续方式:
这种继续方式与私有继续方式的情况相同。两者的区别仅在于对派生类的成员而言,对基类成员有不同的可见性。
上述所说的可见性也就是可访问性。关于可访问性还有另的一种说法。这种规则中,称派生类的对象对基类访问为水平访问,称派生类的派生类对基类的访问为垂直访问。
一般规则如下:
公有继续时,水平访问和垂直访问对基类中的公有成员不受限制;
私有继续时,水平访问和垂直访问对基类中的公有成员也不能访问;
保护继续时,对于垂直访问同于公有继续,对于水平访问同于私有继续。
对于基类中的私有成员,只能被基类中的成员函数和友元函数所访问,不能被其他的函数访问。
基类与派生类的关系
任何一个类都可以派生出一个新类,派生类也可以再派生出新类,因此,基类和派生类是相对而言的。
基类与派生类之间的关系可以有如下几种描述:
1. 派生类是基类的具体化
类的层次通常反映了客观世界中某种真实的模型。在这种情况下,不难看出:基类是对若干个派生类的抽象,而派生类是基类的具体化。基类抽取了它的派生类的公共特征,而派生类通过增加行为将抽象类变为某种有用的类型。
2. 派生类是基类定义的延续
先定义一个抽象基类,该基类中有些操作并未实现。然后定义非抽象的派生类,实现抽象基类中定义的操作。例如,虚函数就属此类情况。这时,派生类是抽象的基类的实现,即可看成是基类定义的延续。这也是派生类的一种常用方法。
3. 派生类是基类的组合
在多继续时,一个派生类有多于一个的基类,这时派生类将是所有基类行为的组合。
派生类将其本身与基类区别开来的方法是添加数据成员和成员函数。因此,继续的机制将使得在创建新类时,只需说明新类与已有类的区别,从而大量原有的程序代码都可以复用,所以有人称类是“可复用的软件构件”。