一个类写出来的时候,它只是躺在一个以.java为后缀的文本文件里,简单地说,就是在硬盘里。写好的Java文件经过编译变成.class文件后,由Java虚拟机装载运行。而运行的时候,类是在内存中表示的。通过new关键字产生的实例,也是在内存中存在的。类的实例在内存中有一定的存储格式(可以参考Java虚拟机规范,对象的存储格式),这跟它还没有被运行时躺在硬盘时的存储格式是不一样的。 序列化,就是将内存中的一个实例,以另外一种存储方式(参考《Core Java》)存储在硬盘中,换个说法就叫持久化。 这样,只要别人拿到这个序列化后的实例的数据,就能通过反序列化把这个对象当时的状态还原出来。 序列化应用的场景有很多,rmi,rpc。可以参考相关资料。
一个类写出来的时候,它只是躺在一个以.java为后缀的文本文件里,简单地说,就是在硬盘里。
写好的Java文件经过编译变成.class文件后,由Java虚拟机装载运行。
而运行的时候,类是在内存中表示的。通过
new
关键字产生的实例,也是在内存中存在的。类的实例在内存中有一定的存储格式(可以参考Java虚拟机规范,对象的存储格式),这跟它还没有被运行时躺在硬盘时的存储格式是不一样的。
序列化,就是将内存中的一个实例,以另外一种存储方式(参考《Core Java》)存储在硬盘中,换个说法就叫持久化。
这样,只要别人拿到这个序列化后的实例的数据,就能通过反序列化把这个对象当时的状态还原出来。
序列化应用的场景有很多,rmi,rpc。可以参考相关资料。