JavaSE知识集锦序列化与反序列化
Posted tanxiaxuan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaSE知识集锦序列化与反序列化相关的知识,希望对你有一定的参考价值。
1、为什么要序列化?
序列化说白了就是把一个对象用一种特定的方式保存起来。就像数据也可以保存为xml文件一样。反序列化就是序列化的逆过程,相当于解冻,重新得到一个新的对象。这样的对象可以永久保存在本地,也能够方便网络的传输。
2、如何序列化?
序列化的类需要实现Serializable接口。不然会抛出java.io.NotSerializableException异常。具体的内容如代码所示。
class A implements Serializable
transient int i = 1;
double j = 2.0;
float k = 3.0f;
class Source
public static void main(String[] args) throws Exception
A a1 = new A();
//新建一个字节数组输出流,位于内存,相当于字节数组。
ByteArrayOutputStream baos = new ByteArrayOutputStream();
//一般用ObjectOutputStream进行序列化
ObjectOutputStream oos = new ObjectOutputStream(baos);
oos.writeObject(a1);
//下面完全是逆过程
ByteArrayInputStream bais = new ByteArrayInputStream(baos.toByteArray());
ObjectInputStream ois = new ObjectInputStream(bais);
A a2 = (A)ois.readObject();
System.out.println("a2.i = " + a2.i);
System.out.println("a2.j = " + a2.j);
System.out.println("a2.k = " + a2.k);
System.out.println("a1.hashCode() = " + a1.hashCode());
System.out.println("a2.hashCode() = " + a2.hashCode());
输出结果如下所示
a2.i = 0
a2.j = 2.0
a2.k = 3.0
a1.hashCode() = 865113938
a2.hashCode() = 1442407170
可以看到反序列化出来的对象和原来不是同一个
3、transient关键字加上了transient关键字之后,反序列化将不能够得到原来的值。可能是默认值(基本类型)或者null(引用类型)。如上面例程所示。
4、serialVersionUID
A a1 = new A();
//新建一个字节数组输出流,位于内存,相当于字节数组。
FileOutputStream fos = new FileOutputStream("object");
//一般用ObjectOutputStream进行序列化
ObjectOutputStream oos = new ObjectOutputStream(fos);
oos.writeObject(a1);
oos.close();
fos.close();
往A类添加了一个新的字段后,想要序列化,但是抛出了java.io.InvalidClassException。如果我们在序列化时和反序列化时都指定一个相同的UID,即时后面新添加了一些字段。也将能够成功序列化。
以上是关于JavaSE知识集锦序列化与反序列化的主要内容,如果未能解决你的问题,请参考以下文章
IO流相关知识(File,字节流,字符流,特殊操作流(标准输入流,标准输出流,对象序列化与反序列化,properties与IO流结合))相关知识总结