1、什么是序列化和反序列化?
Java 提供了一种对象序列化的机制,该机制中,一个对象可以被表示为一个字节序列,该字节序列包括该对象的数据、有关对象的类型的信息和存储在对象中数据的类型。
将序列化对象写入文件之后,可以从文件中读取出来,并且对它进行反序列化,也就是说,对象的类型信息、对象的数据,还有对象中的数据类型可以用来在内存中新建对象。
整个过程都是 Java 虚拟机(JVM)独立的,也就是说,在一个平台上序列化的对象可以在另一个完全不同的平台上反序列化该对象。
2、为什么要进行序列化和反序列化?
https://www.cnblogs.com/chenmingjun/p/9746310.html
3、怎样实现?
实现Serializable,并且传输端和接收端serialVersionUID保持一致。(不实现Serializable,writeObject0中有类别判断:String,Array,Enum,实现Serializable接口;接收端对readObject中的serialVersionUID一致)
4、transient的作用是什么?
屏蔽某些字段使其不被序列化。eg:password
5、怎么自定义序列化策略?
实现writeObject和readObject方法。如果没有这样的方法,则默认调用是 ObjectOutputStream 的 defaultWriteObject 方法以及 ObjectInputStream 的 defaultReadObject 方法。