无论何种类型的数据,都是以二进制的形式在网络上传送,为了由一个进程把Java对象发送给另一个进程,需要把其转换为字节序列才能在网络上传送,把JAVA对象转换为字节序列的过程就称为对象的序列化,将字节序列恢复成Java对象的过程称为对象的反序列化。
序列化的实现:将需要被序列化的类实现Serializable接口,然后使用一个输出流(如:FileOutputStream)来构造一ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。
特点:序列化时,只对对象的状态进行保存,而不管对象的方法。
父类实现序列化时,子类自动实现序列化,而不需要显示实现Serializable接口。
当一对象的实例引用其他对象时将其实例化,被引用对象也会被序列化。
被static或transient修饰的变量,序列化时变量值不会被保存。
优点:实现了数据的持久化,可以将数据永久的存到硬盘上,实现了数据的远程传输。