Java访问权限控制,你知道多少?

要想理解Java访问权限控制,首先要理解Java封装,即面向对象的三个特征之一,它指的是将对象的状态信息隐藏在对象的内部,只有把有限的方法和成员公开给别人,这也是迪米特法则的内在要求,是使外部调用方法对方法体内的实现细节知道的尽可能少。

对一个类或对象实现良好的封装,可以实现以下目的:

  • 隐藏类的细节
  • 让使用者只能通过事先写好的方法来访问数据
  • 可以进行数据检查,从而有利于保证信息的完整性
  • 便于修改,提高代码的可扩展性
访问权限控制符任何地方包外子类包内类内
publicOKOKOKOK
protectedNOOKOKOK
默认NONOOKOK
privateNONONONO
  • 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修饰这些方法。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

半夏_2021

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值