5.4.2 封装的实现—使用访问控制符
Java是使用“访问控制符”来控制哪些细节需要封装,哪些细节需要暴露的。 Java中4种“访问控制符”分别为private、default、protected、public,它们说明了面向对象的封装性,所以我们要利用它们尽可能的让访问权限降到最低,从而提高安全性。
下面详细讲述它们的访问权限问题。其访问权限范围如表5-1所示。
表5-1 访问权限修饰符
private 表示私有,只有自己类能访问
default表示没有修饰符修饰,只有同一个包的类能访问
protected表示可以被同一个包的类以及其他包中的子类访问
public表示可以被该项目的所有包中的所有类访问
下面做进一步说明Java中4种访问权限修饰符的区别:首先我们创建4个类:Person类、Student类、Animal类和Computer类,分别比较本类、本包、子类、其他包的区别。
public访问权限修饰符
图5-8 public访问权限—本类中访问public属性
图5-9 public访问权限—本包中访问public属性
图5-10 public访问权限—不同包中的子类访问public属性
图5-11 public访问权限—不同包中的非子类访问public属性
通过图5-8 ~ 图5-11可以说明,public修饰符的访问权限为:该项目的所有包中的所有类。
protected访问权限修饰符
将Person类中属性改为protected,其他类不修改。
图5-12 protected访问权限—修改后的Person类
图5-13 protected访问权限—不同包中的非子类不能访问protected属性
通过图5-12和图5-13可以说明,protected修饰符的访问权限为:同一个包中的类以及其他包中的子类。
默认访问权限修饰符
将Person类中属性改为默认的,其他类不修改。
图5-14 默认访问权限—修改后的Person类
通过图5-14可以说明,默认修饰符的访问权限为:同一个包中的类。
private访问权限修饰符
将Person类中属性改为private,其他类不修改。
图5-15 private访问权限—修改后的Person类
通过图5-15可以说明,private修饰符的访问权限为:同一个类。