面向对象特征之封装性:
一、问题的引入:
当我们创建一个类的对象以后,我们可以通过”对象.属性”的方式,对对象的属性进行赋值。这里,赋值操作要受到属性的数据类型和存储范围的制约。除此之外,没有其他制约条件。但是,在实际问题中,我们往往需要给属性赋值加入额外的限制条件。这个条件就不能在属性声明时体现,我们只能通过方法进行限制条件的添加。(比如:setLegs())同时,我们需要避免用户再使用”对象.属性”的方式对属性进行赋值。则需要将属性声明为私有的(private).
—>此时,针对于属性就体现了封装性。
二、封装性的体现:
我们将类的属性xxx私有化(private),同时,提供公共的(public)方法来获取(getXxx)和设置(setXxx)此属性的值
拓展:封装性的体现:① 如上 ② 不对外暴露的私有的方法 ③ 单例模式 …
三、封装性的体现,需要权限修饰符来配合。
1.Java规定的4种权限(从小到大排列):private、缺省、protected 、public
2. 4种权限可以用来修饰类及类的内部结构:属性、方法、构造器、内部类
3. 4种权限都可以用来修饰类的内部结构:属性、方法、构造器、内部类
- 修饰类的话,只能使用:缺省、public
- 清楚了解。
Demo:
1 | public class AnimalTest { |
总结封装性:
- Java提供了4种权限修饰符来修饰类及类的内部结构,体现类及类的内部结构在被调用时的可见性的大小。
- 要牢牢掌握实现封装的方法。(代码55~62)