为什么要引入封装性
- 我们程序设计追求“高内聚,低耦合”。
高内聚 :类的内部数据操作细节自己完成,不允许外部干涉;
低耦合 :仅对外暴露少量的方法用于使用。
- 隐藏对象内部的复杂性,只对外公开简单的接口。便于外界调用,从而提高系统的可扩展性、可维护性。通俗的说,把该隐藏的隐藏起来,该暴露的暴露出来。这就是封装性的设计思想。
问题引入
当我们创建一个类的对象以后,我们可以通过”对象.属性”的方式,对对象的属性进行赋值。这里,赋值操作要受到属性的数据类型和存储范围的制约。除此之外,没其他制约条件。但是,在实际问题中,我们往往需要给属性赋值加入额外的限制条件。这个条件就不能在属性声明时体现,我们只能通过方法进行限制条件的添加。(比如:setLegs()同时,我们需要避免用户再使用”对象.属性”的方式对属性进行赋值。则需要将属性声明为私有的(private)。此时,针对于属性就体现了封装性。
信息的封装和隐藏
Java中通过将数据声明为私有的(private),再提供公共的(public) 方法:getXxx()和setXxx()实现对该属性的操作,以实现下述目的:
- 隐藏一个类中不需要对外提供的实现细节;
- 使用者只能通过事先定制好的方法来访问数据,可以方便地加入控制逻辑, 限制对属性的不合理操作;
- 便于修改,增强代码的可维护性;
权限修饰符:
Java权限修饰符public、protected、(缺省)、private置于类的成员定义前, 用来限定对象对该类成员的访问权限。 | 修饰符 | 类内部 | 同一个包 | 不同包的子类 | 同一个工程 | | —- | —- | —- | —- | —- | | private[1] | yes |
|
|
| | (缺省) | yes | yes |
|
| | protected | yes | yes | yes |
| | public | yes | yes | yes | yes |对于class的权限修饰只可以用public和default(缺省)。
- public类可以在任意地方被访问。
- default类只可以被同一个包内部的类访问。
同一个类中
- 可以调用任意权限属性和方法。
- 同一个包中的不同类
- 不可以调用其他类中的private属性、方法;
- 可以调用缺省、protected、public的方法与属性。
- 在不同包的子类中
- 不可以调用其他包中父类中声明为private、缺省权限的属性、方法;
- 可以调用protected、public的方法与属性。
不同包下的普通类(非子类)
- 不可以调用其他包中声明为private、缺省、protected权限的属性、方法;
- 可以调用public的方法与属性。
体现一:将类的属性xxx私有化(private),同时,提供公共的(public)方法来获取
- 体现二:不对外暴露的私有的方法
- 体现三:单例模式(将构造器私有化)
- 体现四:如果不希望类在包外被调用,可以将类设置为缺省的。