Java面试题-Java核心基础-第十三天(序列化)

目录

一、Java序列化与反序列化是什么?

二、为什么需要序列化与反序列化?

三、序列化的实现方式有哪些?

四、什么是serialVersionUID?

五、为什么还要显示指定serialVersionUID

六、serialVersionUID什么时候修改?

七、Java序列化如果有些字段不想序列化,怎么办?

八、静态变量会序列化吗?


一、Java序列化与反序列化是什么?

Java序列化就是将对象转为字节序列

Java反序列化就是将字节序列转为内存中的对象

二、为什么需要序列化与反序列化?

其实大的来说就是为了保存对象的信息 状态信息 因为JVM一旦关闭 其对象也会被销毁 如何持久化对象就需要使用到序列化机制

另外就是为了便于网络传输传输信息,传输字节序列给对方,对方接收到再进行反序列化就能获取到对象信息,像RPC或者是OpenFeign远程调用就是将对象进行序列化与反序列化的过程(其实就是实现分布式对象,多个服务可以使用同一对象)

除此之外,序列化与反序列化机制还能用于实现深拷贝,序列化不仅只序列化当前对象,其对象里面的里面也会递归的序列化

三、序列化的实现方式有哪些?

类实现Serializable接口 或者是实现Externalizable接口

实现Serializable接口的方式很简单,只需要实现这个接口,不需要实现里面的任何方法,因为里面就没方法,然后在类里面指定一个serialVersionUID就行 注意这个必须是static final long的

而实现Externalizable 接口的方式,就更加的灵活了,可以指定我们需要序列化的字段,而如何指定呢?就通过实现Externalizable接口接口中的readExternal和writeExternal方法就可以了

例子:

java 复制代码
public class User implements Externalizable {

   private String name;
   private int age;

   public String getName() {
       return name;
   }
   public void setName(String name) {
       this.name = name;
   }
   public void writeExternal(ObjectOutput out) throws IOException {
       out.writeObject(name);
   }
   public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {
       name = (String) in.readObject();
   }

   @Override
   public String toString() {
       return "User{" +
               "name='" + name +
               '}';
   }
}

两者的对比:

Serializable接口更为简单,它是按照系统默认的序列化规则,能序列化所有属性。但是效率不高

Externalizable接口需要自己重写两个方法,可以指定序列化字段,如果不重写的话,默认是属性类型的默认值 效率高

四、什么是serialVersionUID?

就是一个类的标识,需要依靠这个来反序列化。它的过程是:拿到序列化中的serialVersionUID值,然后与本地的类的serialVersionUID作比较,如果相同则反序列化成本地类对象,如果不同则序列化失败

五、为什么还要显示指定serialVersionUID

如果不显示指定,那么这个值就会根据类的属性来自动生成有一个serialVersionUID值,因此如果类中属性变化了,这个值就会发生变化。

如果再我们序列化之后修改了类中的属性,那么此时这个serialVersionUID值就会与它原先当初序列化时类中的serialVersionUID不一样,所以就会反序列化失败。

因此一般我们要手动的指定一个serialVersionUID值

六、serialVersionUID什么时候修改?

一般的时候不要修改,除非软件不兼容的情况 因为不兼容 所以不允许类随意发生改变

七、Java序列化如果有些字段不想序列化,怎么办?

使用transient修饰 或者类实现Externalizable接口的方式重写方法指定

八、静态变量会序列化吗?

不会,因为静态变量属于类,而序列化的是对象的信息。

至于为什么静态的serialVersionUID可以被序列化 是因为JVM作了特殊判断,因为需要依靠它来进行反序列化

相关推荐
小凡敲代码2 天前
2025年最新Java后端场景面试题(大厂真题+解析)
java·程序员·java面试·java面试题·后端开发·java场景题·2025求职面试
GEM的左耳返19 天前
Java面试实战:企业级性能优化与JVM调优全解析
性能优化·并发编程·java面试·jvm调优·数据库优化·gc算法
GEM的左耳返20 天前
Java面试全攻略:Spring生态与微服务架构实战
spring boot·redis·spring cloud·微服务·kafka·java面试
GEM的左耳返20 天前
Java面试全方位解析:从基础到AI的技术交锋
spring boot·微服务·java面试·互联网大厂·rag技术·ai面试·java技术栈
GEM的左耳返20 天前
互联网大厂Java面试:微服务与AI技术深度交锋
spring cloud·ai·微服务架构·java面试·rag技术
GEM的左耳返20 天前
Java面试实战:从基础到架构的全方位技术交锋
spring boot·微服务·云原生·java面试·技术解析·ai集成
GEM的左耳返20 天前
Java面试新趋势:云原生与新兴框架实战解析
云原生·graalvm·服务网格·java面试·quarkus·micronaut
GEM的左耳返21 天前
Java AI面试实战:Spring AI与RAG技术落地
prompt工程·向量数据库·java面试·rag·ai应用·spring ai
会写代码的斯皮尔伯格23 天前
Spring Boot 3整合Spring AI实战:9轮面试对话解析AI应用开发
openai·微服务架构·java面试·rag·ollama·spring ai·spring boot 3
remCoding1 个月前
Java大厂面试实录:从Spring Boot到AI微服务架构的深度解析
spring boot·redis·kafka·java面试·spring ai·jakarta ee·ai微服务