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;
	}
	
}

猜你喜欢

转载自blog.csdn.net/djd566/article/details/79749757