面向对象程序的三大特性之封装性:把属性和方法封装在一个整体,同时添加权限访问。
1.封装性的简单程序如下,看一下第19行,如果我们不对age变量进行权限的管控,万一我们设置的age为-1,实际上设置age为-1是不合理的,将age的属性设置为private之后,设置age变量只能通过setAge方法进行操作,如果你传进来的age不合理的,那样我们都设置为0,那样就能够拦截下来。
class Persion{
private int age;/* private:私有属性,外部无法直接访问,只有本类内可以访问 */
/* public:公有属性 */
/* age 只能通过 setAge 间接来访问,这里对age进行界定,防止错误操作 */
public void setAge(int age){
if (age < 0 || age > 200)
age = 0;
else
this.age = age;
}
public int getAge(){
return age;
}
}
public class Enc{
public static void main(String args[]){
Persion per = new Persion();
/* 外部设置了一个错误的值(-1),这样显示存在问题,
但是我们可以设置不让外部直接访问,即添加权限*/
//per.age = -1;
per.setAge(-1);
System.out.println(per.getAge());
}
}
那么这样一个简单的例子即包含了封装性所描述的两个含义,一个是成员属性和成员方法的封装即 Person 这个类的封装。另一个信息隐蔽即 age 这个变量设置为 private 属性,只提供有限的对外接口,即 public 方法 setAge ,它只限外部设置的范围为0-200。还有两个关键字“default”、“protected”留到后面进行讲述。