参考:https://juejin.im/entry/5bf622436fb9a04a0b21cbe7
JDK序列化方式中,使用ObjectInputStream#readObject进行反序列化,使用ObjectInputStream#writeObject进行序列化,反序列化稍微复杂点,朋友们可以结合文字看源码
ObjectInputStream#readObject:
A 判断子类是否重写了readObject方法。因为readObject是final修饰,所以实质上重写的是readObjectOveride方法,如果重写了,则直接执行子类重写的readObjectOverride方法。
B 如果没有,则指向readObject0,readObject0就是底层执行反序列化的主要方法:
1 选择反序列化方法
2 如果是反序列化对象,则会执行readOrdinaryObject方法:
1 反序列化创建了新的对象,这就是反序列化可以破坏单例的原因;
2 判断序列化方式,可以看到实现Externalizable接口的方式优先级要高于实现Serializable接口的方式,如果使 用的是Serializable方式,则会执行readSerialData方法:
1 判断被序列化的类中是否包含readObject方法;(hasReadObjectMethod)
2 如果包含,就执行被序列化类中的readObject方法;(HashMap、ArrayList重写了)
3 如果不包含,