欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Java如何做到全面的Safety from rep exposure?

程序员文章站 2024-02-10 09:19:58
...

简单来说,一个主类有属性和方法两种成分,这里的主类是指用户直接使用的类,需要做到以下两点

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