详解Java中的protected修饰的访问权限

简介: 详解Java中的protected修饰的访问权限

前言:在Java中,类成员访问权限修饰词有四类:private,缺省(说白了就是空)着)protected 和 public,private,缺省,和 public的访问权限都很好理解,但是protected的访问权限却使人茫然若迷,一叶蔽目,不见泰山。


先来看一下protected修饰的大体访问权限:

同一个类中 同一个包中 不同包的子类 不同包的无关类
protected             √             √             √             ❌

总结:即protected可以访问的权限为在同一个类中,在同一个包中,继承有protected修饰的类的子类中。

 

这一句话看着简单但是其中有许多的注意点!!!我们挨个分析。

1.同一个类中

如图:

在写一个标准JavaBean时,get 和 set 方法里面都直接调用protected修饰的成员变量,说明可以直接调用。

2.同一个包中

如图:

从上图中,我们可以看到在同一个包中,可以直接使用protected修饰的变量,并且无论是使用子类创建的对象还是父类创建的对象都可以访问protected修饰的变量。

3.不同包的子类

       在不同包的子类中的情况会有些多,所以我们一个个讲解。

(1)有一个包A与父类在同包,但是包B却不在父类所在的包中

从上图中,我们可以看到有一个子类与父类同包,但是另一个子类与父类不同包,同包子类对象可以直接使用protected修饰的变量,另一个子类即使不在自己的作用域内创建对象也可以直接使用protected修饰的变量,并且无论是使用子类创建的对象还是父类创建的对象都可以访问protected修饰的变量。

(2)两个子类的包都不在父类的包中,但是两个子类却同包

从上图中,我们可以看到两个子类和父类都不同包,但是两个子类却同包,在该子类(Dog)的自己的作用域中创建自己的对象调用protected修饰的变量是可以的,但是Cat类在别人的作用域里面创建对象调用不了protected修饰的变量,并且也不可以创建父类的对象调用父类自己的方法。

(3)两个子类的包都不在父类的包中

从上图中,我们可以看到两个子类和父类都不同包,在该子类(Dog)的自己的作用域中创建自己的对象调用protected修饰的变量是可以的,但是Cat类在别人的作用域里面创建对象调用不了protected修饰的变量,并且也不可以创建父类的对象调用父类自己的方法。

注:当父类中的变量被protected修饰的同时还被static修饰,同包子类对象可以直接使protected修饰的变量,另一个子类即使不在自己的作用域内创建对象也可以直接使用protected修饰的变量,父类创建的对象也可以访问protected修饰的变量。(简单来说就是上边的情况全都可以实现了,都不会报错)

相关文章
|
1月前
|
SQL Java 数据库连接
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,有效减少连接开销,提升访问效率。本文介绍了连接池的工作原理、优势及实现方法,并提供了HikariCP的示例代码。
53 3
|
1月前
|
SQL Java 数据库连接
打破瓶颈:利用Java连接池技术提升数据库访问效率
在Java应用中,数据库访问常成为性能瓶颈。连接池技术通过预建立并复用数据库连接,避免了频繁的连接建立和断开,显著提升了数据库访问效率。常见的连接池库包括HikariCP、C3P0和DBCP,它们提供了丰富的配置选项和强大的功能,帮助优化应用性能。
59 2
|
2月前
|
Java
Java访问外网图片地址时,如何添加代理?
【10月更文挑战第14天】Java访问外网图片地址时,如何添加代理?
45 2
|
2月前
|
小程序 Java
小程序访问java后台失败解决方案
小程序访问java后台失败解决方案
53 2
|
2月前
|
小程序 JavaScript Java
小程序访问java后台
小程序访问java后台
30 1
|
2月前
|
存储 Java
深入理解java对象的访问定位
这篇文章深入探讨了Java对象的访问定位机制,比较了使用句柄和直接指针两种主流的对象访问方式,并指出了它们各自的优势,例如句柄访问在对象移动时的稳定性和直接指针访问的速度优势。
35 0
深入理解java对象的访问定位
|
3月前
|
存储 Java 关系型数据库
java: 无法访问org.springframework.context.ConfigurableApplicationContext
`亲测可用,之前搜索了很多博客,啥样的都有,就是不介绍报错以及配置用处,根本不懂照抄那些配置是干啥的,稀里糊涂的按照博客搭完也跑不起来,因此记录这个。` `项目背景`:公司项目当前采用http协议+shiro+mysql的登录认证方式,而现在想支持ldap协议认证登录然后能够访问自己公司的项目网站。 `举例说明`:假设我们公司有自己的门户网站,现在我们收购了一家公司,他们数据库采用ldap存储用户数据,那么为了他们账户能登陆我们公司项目所以需要集成,而不是再把他们的账户重新在mysql再创建一遍,万一人家有1W个账户呢,不累死了且也不现实啊。
64 11
|
3月前
|
安全 Java 编译器
java访问字段
java访问字段
29 6
|
3月前
|
安全 Java 编译器
java访问类字段
java访问类字段
|
3月前
|
安全 Java 开发者
Java修饰符与封装:理解访问权限、行为控制与数据隐藏的重要性
Java中的修饰符和封装概念是构建健壯、易维护和扩展的Java应用程序的基石。通过合理利用访问权限修饰符和非访问修饰符,开发者能够设计出更加安全、灵活且高效的代码结构。封装不仅是面向对象编程的核心原则之一,也是提高软件项目质量和可维护性的关键策略。
34 1
下一篇
DataWorks