要想理解Java访问权限控制,首先要理解Java封装,即面向对象的三个特征之一,它指的是将对象的状态信息隐藏在对象的内部,只有把有限的方法和成员公开给别人,这也是迪米特法则的内在要求,是使外部调用方法对方法体内的实现细节知道的尽可能少。
对一个类或对象实现良好的封装,可以实现以下目的:
- 隐藏类的细节
- 让使用者只能通过事先写好的方法来访问数据
- 可以进行数据检查,从而有利于保证信息的完整性
- 便于修改,提高代码的可扩展性
访问权限控制符 | 任何地方 | 包外子类 | 包内 | 类内 |
public | OK | OK | OK | OK |
protected | NO | OK | OK | OK |
默认 | NO | NO | OK | OK |
private | NO | NO | NO | NO |
- public : 可以修饰外部类、属性、方法,表示公开的、无限制的,是访问限制最松的,被其修饰的类、属性和方法不仅可以被包内访问,还可以跨类、跨包访问,甚至允许跨工程访问。
- protected : 只能修改属性和方法,表示受保护的、有限制的,被其修饰的属性 和方法能被包内及包外子类访问。如果使用了protected 来修饰一个方法,通常是希望其子类来重写这个方法。
- 无:即无任何访问权限修饰符,无访问权限控制符仅对包内可见。
- private : 只能修饰属性、方法、内部类。这个成员只能在当前类的内部被访问。这个访问控制符用于修饰成员变量最合适,使用它来修饰成员变量就可以把成员变流量隐藏在该类的内部。
关于访问控制符的使用,存在如下几条基本原则:
1. 如果不允许外部直接通过new创建对象,构造方法必须是private
2. 工具类不允许有public 或 default构造方法
3. 类非static成员变量并且 与子类共享,必须是protected
4. 类非static 成员变量并且仅在本类使用,必须private
5. 类static成员变量如果仅在本类 使用,必须是private
6. 若是static成员变量,必须考虑是否为final类成员方法只供类内部使用,必须为private
7. 如果某个类主要用做其他类的父类,该类里面包含的大部分方法可能仅希望被其子类重写,而不想被外界直接调用,则应该使用 protected修饰这些方法。