Map里面存的也都是对象,是对象就要判断是不是引用类型。String是个不可变类,所以String类型是不会有问题的。一些数值型的变量如Long,Double这些数据,以及一些对象如果存在key上,只要不做修改也没有问题。但是只要是对象,难免什么时候被人修改,问题就来了,key是不能重复的,修改了也不能重复。另外取数据时,如何用key取出数据来,这就需要我们下面的一些特殊处理了。
1、如果非要将对象存入key/value中,那么这个对象里面可以重写一下这两个方法。
@Override
public boolean equals(Object obj) {
if (null == obj) {
return false;
}
if (!(obj instanceof User)) {
return false;
}
User tmpObj = (User) obj;
// return tmpObj.getName().equals(name)
// && tmpObj.getPassword().equals(password);
return tmpObj.name==name&&tmpObj.password==password;
}
@Override
public int hashCode() {
int ret = new String(name).hashCode() ^ new String(password).hashCode();
// 也可以用下面这种方式计算hashCode
// int ret = String.valueOf(id).hashCode() ^ String.valueOf(type).hashCode();
//System.out.println(ret);
return ret;
}
}
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.List;
public class DeepCopy<T> {
public static <T> List<T> deepCopy(List<T> src) throws IOException, ClassNotFoundException {
ByteArrayOutputStream byteOut = new ByteArrayOutputStream();
ObjectOutputStream out = new ObjectOutputStream(byteOut);
out.writeObject(src);
ByteArrayInputStream byteIn = new ByteArrayInputStream(byteOut.toByteArray());
ObjectInputStream in = new ObjectInputStream(byteIn);
@SuppressWarnings("unchecked")
List<T> dest = (List<T>) in.readObject();
return dest;
}
}
3、还有一个办法,那就是让对象继承Clone类,然后在类中实现Clone方法,在这里面你重建对象,重新分配内存,仔细考量一番,这里面也是存在浅拷贝、深拷贝的,里面的东西不少,下一篇我们来探讨。这样当你想要深拷贝一个类时,直接调用Clone方法即可。