一、为什么要引入封装性?
我们程序设计追求“高内聚,低耦合”。
>高内聚 :类的内部数据操作细节自己完成,不允许外部干涉;
>低耦合 :仅对外暴露少量的方法用于使用。
>隐藏对象内部的复杂性,只对外公开简单的接口。便于外界调用,从而提 高系统的可扩展性、可维护性。
通俗的说,把该隐藏的隐藏起来,该暴露 的暴露出来。这就是封装性的设计思想。
二、问题引入
当创建对象,使用对象调用类的属性与方法时,对象的属性进行赋值操作时,只受到数据类型和数据类型存储范围的限制。而现实问题中,我们往往需要额外限制属性的范围,这是在定义属性时做不到的。我们只能通过方法的定义来实现,并且需要避免再用"对象.属性"来赋值。需要将属性定义为私有的(private)。此时,就体现了面向对象的封装性。
三、封装性思想具体的代码体现
体现一:我们将类的属性私化(private),然后设置公共的方法(getXxx好setXxx)来设置和获取私化的属性的值。
private double radius;
public Circle(double radius){
this.radius = radius;
}
public double getRadius() {
return radius;
}
体现二:类中声明的私化的方法
体现三:单例模式(私有化构造器)
体现四:如果想要一个类只在同一个包内调用,那么可以将类设置为缺省的。
四、Java规定的四种权限修饰符
4.1 权限从小到大顺序为:private、缺省、protected、public
4.2 具体的修饰范围:
4.3 权限修饰符可用来修饰的结构说明:
①权限修饰符的权限从小到大依次是:private、缺省、protected、public。
②四种权限修饰符可以修饰类及类的内部结构:属性、方法、构造器、内部类。
③具体的:四种权限修饰符可以修饰类的内部结构:属性、方法、构造器、内部类。
而类只能使用缺省、public两种权限修饰符来修饰。