hello,everyone,我是徐先生。
最近在准备面试的事情,所以近期会有比较多的基础性素材出现,并以问答形式彰显给大家。话不多说,咱们开始吧!
- 什么是序列化和反序列化?
序列化其实是将Java对象转换成字节流的过程。
而反序列化就是将字节流转换成Java对象的过程。从而实现对数据的存储和传输操作。 - 序列化如何实现?
若某类要实现序列化,则需要实现serializable接口,serializable接口没有需要实现的方法,它只是一个通知JVM,JVM可以将该类实现对象序列化的标示,。通常我们需要在代码中,使用writeObject(Object obj)和readObject(Object obj)两个方法,实现读写操作。 - 为什么要实现序列化?
在web开发中,如果对象被保存到了session中,当Tomcat启动时要将该session对象序列化到磁盘中。如果对象要经过分布式系统进行网络传输,或通过rmi等远程调用,这就需要在网络上传输对象,被传输的对象就要实现serializable接口,进行序列化。 - 进行序列化时,必须声明serialVersionUID变量吗?为什么?
如果我们没有自己声明一个serialVersionUID变量,则系统会自动默认声明一个serialVersionUID变量,当被序列化对象的信息发生改变时,系统又会重新声明一个serialVersionUID变量,此时,会导致在该对象被反序列化时,因为匹配不上原来的serialVersionUID,而产生invalidClassException异常。