什么是java序列化,如何实现java序列化

序列化:就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进流化。可以对流化后的对象进行读写操作,也可以将流化后的对象传输与网络之间;序列化是为了解决在对对象流进行读写操作时引发的问题。

序列化的实现,将需要被序列化的类实现Serializable接口,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出,用恢复的话则用输入流。

java串行化技术可以使你将一个对象的状态写入一个Byte流里,并且可以从其他地方把该Byte流里的数据读出来,重新构造一个相同的对象,这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到数据库,文件等系统中,java的串行化机制是RMI,EJB等技术的技术基础,用途:利用对象的串行化实现保存应用程序的当前工作状态,下次在启动的时候将自动的恢复到上次执行的状态;


通俗的说:
  我们有时候将一个java对象变成字节流的形式传出去或者从一个字节流中恢复成一个java对象,例如:要将java对象存储到硬盘或者传送给网络上的其他计算机,这个过程我们可以自己写代码去把一个java对象编程某个格式的字节流在传输,但是,jre本身就提供了这种支持,我们可以调用OutputStream的writeObject方法来做,如果要让java帮我们做,要被传输对象必须实现serilizable接口,这样,javac编译时就会进行特殊处理,编译的类才可以被writeObject方法操作,这就是所谓的序列化。需要被序列化的类必须实现serializable接口,该接口是一个mini接口,其中没有需要实现的方法,implements Serializable只是为了标注对象时可被序列化的;

例如:在web开发中,如果对象被保存在了session中,tomcat在重启时要把Session对象序列化到硬盘,这个对象就必须实现Serializable接口,如果对象要经过分布式系统进行网络传输或通过rmi等远程调用,这就需要网络上传输对象,被传输的对象必须实现Serializable接口;
串行化的特点:
  (1)如果某个类能够被串行化,其子类也可以被串行化,如果该类有父类,则分为两种情况来考虑,如果该父类已经是想了可串行化接口,则其父类的相应字段及属性的处理和该类相同;如果该类的父类没有实现可串行化接口,则该类的父类所有的字段属性将不会串行化。
(2)声明为static 和transient类型的成员数据不能被串行化。因为static代表类的状态,transient代表对象的临时数据;
(3)相关的类的接口,在java.io包中提供的涉及对象的串行化的类与接口有ObjectOutput接口,ObjectOutputStream类,ObjectInput接口,ObjectInputStream类。
      (1)ObjectOutput接口:它继承DataOutput接口并且支持对象的串行化,其内的writeObject()方法实现存储一个对象。ObjectInput接口:它继承DataInput接口并且支持对象的串行化,其内的readObject()方法实现读取一个对象。

    (2)ObjectOutputStream类:它继承OutputStream类并且实现ObjectOutput接口。利用该类来实现将对象存储(调用ObjectOutput接口中的writeObject()方法)。ObjectInputStream类:它继承InputStream类并且实现ObjectInput接口。利用该类来实现读取一个对象(调用ObjectInput接口中的readObject()方法)。

  对于父类的处理,如果父类没有实现串行化接口,则其必须有默认的构造函数(即没有参数的构造函数)。否则编译的时候就会报错。在反串行化的时候,默认构造函数会被调用。但是若把父类标记为可以串行化,则在反串行化的时候,其默认构造函数不会被调用。这是为什么呢?这是因为Java 对串行化的对象进行反串行化的时候,直接从流里获取其对象数据来生成一个对象实例,而不是通过其构造函数来完成。

你可能感兴趣的:(java)