众所周知,JAVA提供了许多级别的访问权限,从而可以精确的控制类、超类以及包中变量和成员的可见性。从而更好的实现封装、继承,多态。现在我们将对每一种包访问权限做一些说明,可能有遗漏或者错误,请大家多多指正。这里我们主要分析类成员的包访问权限。
因为类和包的相互影响,对于JAVA中的类成员(变量及方法),主要表现为五种类型的可见性:
1、类本身。
2、相同包中的子类。
3、相同包中的非子类。
4、不同包中的子类。
5、不同包中的非子类。
而对于访问权限,JAVA又提供了三个关键字以及默认权限作出对应处理,分别为private,默认访问权限,protected,public,具体关系如下表。虽然看起来有些复杂,但是我们可以对其进行如下简化理解:
- 所有申明为public的成员可以在任何地方进行访问。
- 所有申明为private的成员在当前类外部都为不可见。
- 如果是默认访问权限,只有当前包下的类可见,其他包中子类也无法访问。
- 所有申明为protected的成员,在默认权限的基础上,其他包中子类也可以访问。
private | 默认访问权限 | protected | public | |
类本身 | 是 | 是 | 是 | 是 |
相同包中子类 | 否 | 是 | 是 | 是 |
相同包中的非子类 | 否 | 是 | 是 | 是 |
不同包中的子类 | 否 | 否 | 是 | 是 |
不同包中的非子类子类 | 否 | 否 | 否 | 是 |