1.为什么要引入封装性?
我们程序设计追求“高内聚,低耦合”
-
高内聚:类的内部数据操作细节自己完成,不允许外部干涉
-
低耦合:仅对外暴露少量的方法用于使用。
隐藏对象内部的复杂性,只对外公开简单的接口。便于外界调用,从而提高系统的可扩展性、可维护性。 通俗的说,把该隐藏的隐藏起来,该暴露的暴露岀来。这就是封装性的设计思想。
2.问题引入
当我们创建一个类的对象以后,我们可以通过”对象.属性”的方式,对对象的属性进行赋值。 这里,赋值操作要受到属性的数据类型和存储范围的制约。除此之外,没其他制约条件。 但是,在实际问题中,我们往往需要给属性赋值加入额外的限制条件。 这个条件就不能在属性声明时体现,我们只能通过方法进行限制条件的添加。 (比如:setName()同时,我们需要避免用户再使用”对象.属性”的方式对属性进行赋值。 则需要将属性声明为私有的(private)。此时,针对于属性就体现了封装性。
3.封装性思想具体的代码体现
将数据和方法包装进类中并把具体实现隐藏被称作是封装
体现一:
将类的属性xxx私有化(private)的同时,提供公共的(public)方法来获取(getXxx)和设置(setXxx)此属性的值
public class Circle{
private double radius;
public Circle(){}
public void setRadius(double radius){
this.radius = radius;
}
public double getRadius(){
return radius;
}
}
体现二:
不对外暴露的私有的方法
体现三:
单例模式(将构造器私有化)
体现四:
不对外暴露的私有的方法
4.Java规定的四种权限修饰符
通过对不同的方法属性设置不同的权限修饰符来达到对类进行封装的目的。
-
权限从小到大顺序为:private < 缺省 < protected < public
-
具体的修饰范围:
| 修饰符 | 类内部 | 同一个包 | 不同包的子类 | 同一个工程 |
|---|---|---|---|---|
| private | Yes | |||
| 缺省 | Yes | Yes | ||
| protected | Yes | Yes | Yes | |
| public | Yes | Yes | Yes | Yes |
权限修饰符可用来修饰的结构说明:
-
4种权限都可以用来修饰类的内部结构:属性、方法、构造器、内部类
-
修饰类,只能使用:缺省、public