关于JAVA的包访问权限

技术 2019-01-29


众所周知,JAVA提供了许多级别的访问权限,从而可以精确的控制类、超类以及包中变量和成员的可见性。从而更好的实现封装、继承,多态。现在我们将对每一种包访问权限做一些说明,可能有遗漏或者错误,请大家多多指正。这里我们主要分析类成员的包访问权限。

因为类和包的相互影响,对于JAVA中的类成员(变量及方法),主要表现为五种类型的可见性:

1、类本身。
2、相同包中的子类。
3、相同包中的非子类。
4、不同包中的子类。
5、不同包中的非子类。 


而对于访问权限,JAVA又提供了三个关键字以及默认权限作出对应处理,分别为private,默认访问权限,protected,public,具体关系如下表。虽然看起来有些复杂,但是我们可以对其进行如下简化理解:

  • 所有申明为public的成员可以在任何地方进行访问。 

  • 所有申明为private的成员在当前类外部都为不可见。

  • 如果是默认访问权限,只有当前包下的类可见,其他包中子类也无法访问。

  • 所有申明为protected的成员,在默认权限的基础上,其他包中子类也可以访问。


   private     默认权限访问  protected  public
 类本身  是 是 
 相同包中子类  否 是  是  是 
 相同包中的非子类  否 是  是  是 
 不同包中的子类  否 否  是  是 
 不同包中的非子类  否  否 否  是 


楼主残忍的关闭了评论