为什么要引入封装性

  • 我们程序设计追求“高内聚,低耦合”。

高内聚 :类的内部数据操作细节自己完成,不允许外部干涉;
低耦合 :仅对外暴露少量的方法用于使用。

  • 隐藏对象内部的复杂性,只对外公开简单的接口。便于外界调用,从而提高系统的可扩展性、可维护性。通俗的说,把该隐藏的隐藏起来,该暴露的暴露出来。这就是封装性的设计思想。

问题引入

当我们创建一个类的对象以后,我们可以通过”对象.属性”的方式,对对象的属性进行赋值。这里,赋值操作要受到属性的数据类型和存储范围的制约。除此之外,没其他制约条件。但是,在实际问题中,我们往往需要给属性赋值加入额外的限制条件。这个条件就不能在属性声明时体现,我们只能通过方法进行限制条件的添加。(比如:setLegs()同时,我们需要避免用户再使用”对象.属性”的方式对属性进行赋值。则需要将属性声明为私有的(private)。此时,针对于属性就体现了封装性。

信息的封装和隐藏

Java中通过将数据声明为私有的(private),再提供公共的(public) 方法:getXxx()和setXxx()实现对该属性的操作,以实现下述目的:

  1. 隐藏一个类中不需要对外提供的实现细节;
  2. 使用者只能通过事先定制好的方法来访问数据,可以方便地加入控制逻辑, 限制对属性的不合理操作;
  3. 便于修改,增强代码的可维护性;

image.png

权限修饰符:

  • Java权限修饰符public、protected、(缺省)、private置于类的成员定义前, 用来限定对象对该类成员的访问权限。 | 修饰符 | 类内部 | 同一个包 | 不同包的子类 | 同一个工程 | | —- | —- | —- | —- | —- | | private[1] | yes |
    |
    |
    | | (缺省) | yes | yes |
    |
    | | protected | yes | yes | yes |
    | | public | yes | yes | yes | yes |

  • 对于class的权限修饰只可以用public和default(缺省)。

    1. public类可以在任意地方被访问。
    2. default类只可以被同一个包内部的类访问。
  • 同一个类中

    1. 可以调用任意权限属性和方法。
  • 同一个包中的不同类
    1. 不可以调用其他类中的private属性、方法;
    2. 可以调用缺省、protected、public的方法与属性。
  • 在不同包的子类中
    1. 不可以调用其他包中父类中声明为private、缺省权限的属性、方法;
    2. 可以调用protected、public的方法与属性。
  • 不同包下的普通类(非子类)

    1. 不可以调用其他包中声明为private、缺省、protected权限的属性、方法;
    2. 可以调用public的方法与属性。
                                          • [刷新]
                                            [1]父类中的属性和方法被私有化后,子类无法直接调用

                                            封装性的提现:

  • 体现一:将类的属性xxx私有化(private),同时,提供公共的(public)方法来获取

  • 体现二:不对外暴露的私有的方法
  • 体现三:单例模式(将构造器私有化)
  • 体现四:如果不希望类在包外被调用,可以将类设置为缺省的。