1.派生类的定义
派生类语法如下:
class <派生类名> : <继承方式> <基类名>
{
private:
派生类新增成员;
protected:
派生类新增成员;
public:
派生类新增成员;
};
说明:
(1)class:类声明的关键字;
(2)派生类名:新(派生)类名;
(3)继承方式:指出继承的方式是什么。继承方式包含以下3种。
• public(公有继承方式)使用的最多;
• private(私有继承方式);
• protected(保护继承方式)。
用来说明对于从基类继承来的成员的访问权限,这个稍后介绍。
如果不写继承方式,则默认为 private(私有继承方式)。
(4)基类名:指明派生类是由哪个基类继承而来的。
(5)派生类的成员包括如下3种。
• 吸收基类成员:派生类继承了基类的除了构造函数和析构函数以外的全部数据成员和函数成员。
• 新增成员:增添新的数据成员和函数成员,体现了派生类与基类的不同和个性,是派生类对基类的发展。
• 对基类成员进行改造,包含两层含义:一是对基类成员的访问控制方式进行改造;二是定义与基类同名的成员,即同名覆盖。
class A
{
private:
int m_a;
protected:
int m_b;
public:
int m_c;
};
class B :public A //B是A的派生类
{
private:
int m_d;
};
int main()
{
cout << "A的大小=" << sizeof(A) << ",B的大小=" << sizeof(B) << endl;
return 0;
}
程序执行结果如下:
B的大小为16,说明它把A中的3个成员变量全部继承了。
下面的代码把继承方式由public改为private
class A
{
private:
int m_a;
protected:
int m_b;
public:
int m_c;
};
class B :private A //B是A的派生类,继承方式改为private
{
private:
int m_d;
};
int main()
{
cout << "private继承" << endl;
cout << "A的大小=" << sizeof(A) << ",B的大小=" << sizeof(B) << endl;
return 0;
}
程序执行结果如下:
说明:
基类的所有数据成员都被派生类继承,和基类成员的访问权限无关及继承方式无关。(m_a,m_b,m_c)的访问权限不同
B类的内存图如下:
class Base//基类
{
public:
void show()
{
cout << m_name << "," << m_a << endl;
}
public:
string m_name; //名字
int m_a; //值
};
class Derived :public Base //派生类继承了基类的成员
{
//什么都没有增加
};
int main()
{
Derived d;
d.m_a = 10;
d.m_name = "派生类";
d.show();
return 0;
}
从上面的执行结果可以看出,派生类虽然什么都没有写,但它继承了基类的成员数据(m_a和m_name)和成员函数(show)。
2. 继承方式和派生类的访问权限
派生类继承了基类的数据成员和成员函数,但是这些成员并不都能直接被派生类所访问。采用不同的继承方式,决定了基类成员在派生类中的访问权限。
在C++程序设计中,提供了3种继承方式:公有继承(public)、保护继承(protected)和私有继承(private)。访问权限public > protected > private 。下表为不同继承方式下,派生类对于从基类继承的成员的访问权限。
注意:protected不能在类外访问,它和private的区别是在继承时有区别,不继承时没有区别。
访问属性
继承方式
总结:1.private成员不能被派生类访问;2.权限按小的合并。
1.公有继承(public)
使用的最多的继承方式。
父类中的私有不能在子类中访问,公有还是公有,保护还是保护。
class A
{
public:
void show1()
{
cout << "A::show1(),公有方法" << endl;
}
protected:
void show2()
{
cout << "A::show2(),保护方法" << endl;
}
private:
void show3()
{
cout << "A::show3(),私有方法" << endl;
}
public:
int m_a = 0;
protected:
int m_b = 1;
private:
int m_c = 2;
};
class B :public A
{
public:
void show()
{
show1();//可以,继承下来是public,,可以在类外访问
show2();//可以,继承下来是protected,不可以在类外访问
//show3();//不能访问
cout << m_a << endl;//可以,继承下来是public,可以在类外访问
cout << m_b << endl;//可以,继承下来是protected,不可以在类外访问
//cout << m_c << endl;//不能访问
}
};
int main()
{
B bb;
bb.show1();//public可以在类外访问
//bb.show2();//错误,protected不能在类外访问
bb.m_a = 100;//public可以在类外访问
//bb.m_b = 200;//错误,protected不能在类外访问
bb.show();//public可以在类外访问
return 0;
}
说明:
(1).A中的show1,show2方法可以在子类B中被访问(第30,31行),但A中的私有方法show3在子类B中不能被访问(第32行)。
(2).show1在B中是公有,那么在类外也能被访问(第43行),但show2在B中是保护,在类外不能被访问(第44行)。
(3).A中的m_a,m_b可以在子类B中被访问(第34,35行)。但A中的私有成员m_c在子类B中不能被访问(第36行)。
(4).m_a在B中是公有,那么在类外也能被访问(第46行),但m_b在B中是保护,在类外不能被访问(第47行)。
2.保护继承(protected)
父类中的私有不能在子类中访问,公有变保护,保护还是保护。
//保护继承
class A
{
public:
void show1()
{
cout << "A::show1(),公有方法" << endl;
}
protected:
void show2()
{
cout << "A::show2(),保护方法" << endl;
}
private:
void show3()
{
cout << "A::show3(),私有方法" << endl;
}
public:
int m_a = 0;
protected:
int m_b = 1;
private:
int m_c = 2;
};
class B :protected A
{
public:
void show()
{
show1();//可以
show2();//可以
//show3();//不能访问
cout << m_a << endl;//可以
cout << m_b << endl;//可以
//cout << m_c << endl;//不能访问
}
};
int main()
{
B bb;
//bb.show1();//错误,protected不能在类外访问
//bb.show2();//错误,protected不能在类外访问
//bb.m_a = 100;错误,protected不能在类外访问
//bb.m_b = 200;//错误,protected不能在类外访问
bb.show();//public可以在类外访问
return 0;
}
3.私有继承(private)
父类的私有在子类中不能访问,公有变私有,保护变私有。
//私有继承
class A
{
public:
void show1()
{
cout << "A::show1(),公有方法" << endl;
}
protected:
void show2()
{
cout << "A::show2(),保护方法" << endl;
}
private:
void show3()
{
cout << "A::show3(),私有方法" << endl;
}
public:
int m_a = 0;
protected:
int m_b = 1;
private:
int m_c = 2;
};
class B :private A
{
public:
void show()
{
show1();//可以
show2();//可以
//show3();//不能访问
cout << m_a << endl;//可以
cout << m_b << endl;//可以
//cout << m_c << endl;//不能访问
}
};
int main()
{
B bb;
//bb.show1();//错误,protected不能在类外访问
//bb.show2();//错误,protected不能在类外访问
//bb.m_a = 100;错误,protected不能在类外访问
//bb.m_b = 200;//错误,protected不能在类外访问
bb.show();//public可以在类外访问
return 0;
}
说明:私有继承从上面看貌似和保护继承没有什么区别,实际上有区别,如果C再继承B,那么结果就不一样了。