Java如何做到全面的Safety from rep exposure?
简单来说,一个主类有属性和方法两种成分,这里的主类是指用户直接使用的类,需要做到以下两点
1、将类中所有的属性(变量)定义为private类型,目的是不让用户得到你的内部属性
2、方法或者返回immutable data,或者返回本应该返回的mutable data的副本,或者返回一个不可修改的mutable data
为了做到第二点的三个方面
1、尽量使用immutable数据类型,比如能使用String就不使用StringBuilder,能使用Instance就不使用Data
2、为了创造mutable data的副本,可以进行defensive copy。可以在主类方法中构造然后返回,但是推荐方法是使用mutable数据类型的clone,假如该mutable数据类型是自己写的类,那么推荐在类中写一个clone的方法
3、使用Collections.unmodifiableSet等方法
这里需要注意的是第二个方面,如果想要返回一个Collection类的数据,有人说我创建了一个Collection类,向里面添加数据后,不管数据怎样,都算defensive copy了,但是如果数据是mutable类型,那么就不算defensive copy,因为Collection类储存的是地址,尽管new了一个hashSet或者hashMap,但是没有真正的对mutable数据进行defensive copy。
如果觉得很抽象,那么运行下面的代码就明白了,注StringBuilder为mutable数据类型
public class practice {
public static void main(String[] argvs)
{
List<name> nameList = new ArrayList<>();
StringBuilder sa = new StringBuilder("a");
name a = new name(sa);
System.out.println(a.getName());
nameList.add(a);
nameList.get(0).getName().append("b");
System.out.println(a.getName());
}
}
class name{
private StringBuilder name;
public name(StringBuilder name)
{
this.name = name;
}
public StringBuilder getName() {
return name;
}
}
上一篇: Day_03
下一篇: java day_03