注:本文摘自unixfy博文,感谢作者整理!
关于访问权限和继承方式
访问权限有三种:public、protected、private
继承也有三种:public、protected、private,这里不考虑 virtual 继承。
继承时的权限,不是针对本类内的访问权限,而是针对该派生类的客户端代码(包括其派生类)的访问权限。
即是,对于基类中的 public、protected 成员,如果一个派生类 private 继承自该基类,则这些成员还是可以在派生类中访问的,只是不能在该派生类的客户代码中被直接访问,或者在该派生类的派生类中直接访问。
也就是说,继承的方式是针对派生类的客户端代码来讲的,对派生类内部不起作用,不管是 public、protected、private 继承,派生类中总是可以访问基类中的 public、protected 成员,基类中的 private 成员永远不能在派生类中直接访问,不论通过哪种方式。
归纳一下:
成员访问权限 继承方式 派生类中能否访问 派生类的派生类中 派生类的客户端代码
public public 能 能 能
public protected 能 能 不能
public private 能 不能 不能
protected public 能 能 不能
protected protected 能 能 不能
protected private 能 不能 不能
private public 不能 不能 不能
private protected 不能 不能 不能
private private 不能 不能 不能
从这个表中,我们更能清除地看到成员访问权限和继承方式之间的组合,对派生类中的访问、派生类的派生类中的访问、派生类的客户端代码的访问控制情况。
继承的方式是在原有基类访问权限的基础上,给在派生类的访问权限又加了一个效应。取两个中最严格的那个权限,这个取得的权限是派生类成员的访问权限,而这种访问权限对派生类的客户端代码和派生类的派生类代码其访问控制作用。