要想理解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修饰这些方法。