1.实现序列化:

1)让类实现Serializable接口,该接口是一个标志性接口,标注该类对象是可被序列

2)然后使用一个输出流来构造一个对象输出流并通过writeObect(Obejct)方法就可以将实现对象写出

3)如果需要反序列化,则可以用一个输入流建立对象输入流,然后通过readObeject方法从流中读取对象

2.作用:

1)序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化,可以对流化后的对象进行读写操作,也可以将流化后的对象传输与网络之间;

2)为了解决对象流读写操作时可能引发的问题(如果不进行序列化,可能会存在数据乱序的问题)

3)序列化除了能够实现对象的持久化之外,还能够用于对象的深度克隆

上面说的很抽象,接下来看例子 具体点:

第一步:创建一个 JavaBean 对象

public  class  Person  implements  Serializable{
     private  String name;
     private  int  age;
     
     public  String getName() {
         return  name;
     }
     public  void  setName(String name) {
         this .name = name;
     }
     public  int  getAge() {
         return  age;
     }
     public  void  setAge( int  age) {
         this .age = age;
     }
     @Override
     public  String toString() {
         return  "Person [name="  + name +  ", age="  + age +  "]" ;
     }
     public  Person(String name,  int  age) {
         super ();
         this .name = name;
         this .age = age;
     }
}

第二步:使用 ObjectOutputStream 对象实现序列化

//在根目录下新建一个 io 的文件夹
         OutputStream op =  new  FileOutputStream( "io" +File.separator+ "a.txt" );
         ObjectOutputStream ops =  new  ObjectOutputStream(op);
         ops.writeObject( new  Person( "vae" , 1 ));
         
         ops.close();

我们打开 a.txt 文件,发现里面的内容乱码,注意这不需要我们来看懂,这是二进制文件,计算机能读懂就行了。
如果新建的 Person 对象没有实现 Serializable 接口,那么上面的操作会报java.io.NotSerializableException

第三步:使用ObjectInputStream 对象实现反序列化

反序列化的对象必须要提供该对象的字节码文件.class

InputStream in =  new  FileInputStream( "io" +File.separator+ "a.txt" );
         ObjectInputStream os =  new  ObjectInputStream(in);
         byte [] buffer =  new  byte [ 10 ];
         int  len = - 1 ;
         Person p = (Person) os.readObject();
         System.out.println(p);   //Person [name=vae, age=1]
         os.close();

问题1:如果某些数据不需要做序列化,比如密码,比如上面的年龄?

解决办法:在字段面前加上 transient

private String name; //需要序列化
transient private int age; //不需要序列化
  那么我们在反序列化的时候,打印出来的就是Person [name=vae, age=0],整型数据默认值为 0

问题2:序列化版本问题,在完成序列化操作后,由于项目的升级或修改,可能我们会对序列化对象进行修改,比如增加某个字段,那么我们在进行反序列化就会报错:

解决办法:在 JavaBean 对象中增加一个 serialVersionUID 字段,用来固定这个版本,无论我们怎么修改,版本都是一致的,就能进行反序列化了

private static final long serialVersionUID = 8656128222714547171L;