【面试题精讲】如果有些字段不想进行序列化怎么办?

简介: 【面试题精讲】如果有些字段不想进行序列化怎么办?

!! 有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准https://blog.zysicyj.top

首发博客地址[1]

面试题手册[2]

系列文章地址[3]


如果某些字段不想进行序列化,可以使用 transient 关键字来修饰这些字段。在 Java 中,被 transient 修饰的字段将不会被默认的序列化机制处理。

1. 什么是 transient 关键字?

transient 是 Java 语言提供的一个关键字,用于修饰类的成员变量。当一个字段被 transient 修饰时,在对象进行序列化过程中,该字段的值将不会被保存和传输。

2. 为什么需要使用 transient 关键字?

有时候,我们可能希望某些字段不参与对象的序列化过程。例如,某个字段包含敏感信息或者无需持久化到磁盘等场景下,就可以使用 transient 关键字来标记这些字段,避免其被序列化。

3. transient 关键字的实现原理

在 Java 中,对象的序列化是通过 ObjectOutputStream 类的 writeObject 方法实现的。当调用 writeObject 方法时,它会检查对象的每个字段是否被 transient 修饰,如果被修饰,则跳过该字段的序列化操作。

4. 使用示例

下面是一个简单的示例代码,演示了如何使用 transient 关键字来控制字段的序列化:

import java.io.Serializable;
public class User implements Serializable {
    private String username;
    private transient String password;
    // 省略构造方法和其他方法
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
}

在上面的示例中,User 类有两个字段:username 和 password。其中,password 字段被 transient 修饰,表示不参与序列化过程。

import java.io.*;
public class Main {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        User user = new User();
        user.setUsername("admin");
        user.setPassword("123456");
        // 将对象序列化到文件
        ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("user.ser"));
        oos.writeObject(user);
        oos.close();
        // 从文件反序列化对象
        ObjectInputStream ois = new ObjectInputStream(new FileInputStream("user.ser"));
        User deserializedUser = (User) ois.readObject();
        ois.close();
        System.out.println(deserializedUser.getUsername()); // 输出:admin
        System.out.println(deserializedUser.getPassword()); // 输出:null
    }
}

在上面的示例中,我们创建了一个 User 对象,并将其序列化到文件中。然后再从文件中反序列化出来。可以看到,由于 password 字段被 transient 修饰,所以在反序列化时,该字段的值为 null。

5. transient 关键字的优点

  • 可以避免某些敏感信息或无需持久化的字段被序列化和传输,提高数据的安全性。
  • 可以减少序列化对象的大小,节省网络带宽和存储空间。

6. transient 关键字的缺点

  • 被 transient 修饰的字段在反序列化后会变为默认值(如 null、0 等),可能需要额外的处理来恢复其原有的值。

7. transient 关键字的使用注意事项

  • 被 transient 修饰的字段必须是可序列化的类的成员变量,否则编译时会报错。
  • 在进行对象的深度拷贝或克隆时,被 transient 修饰的字段也不会被复制。

8. 总结

transient 关键字可以用于控制 Java 对象的序列化过程,使某些字段不参与序列化。通过对敏感信息或无需持久化的字段使用 transient 修饰,可以提高数据的安全性,并减少序列化对象的大小。但需要注意,在反序列化后,被 transient 修饰的字段会变为默认值,可能需要额外的处理来恢复其原有的值。

参考资料

[1]

首发博客地址: https://blog.zysicyj.top/

[2]

面试题手册: https://store.amazingmemo.com/chapterDetail/1685324709017001

[3]

系列文章地址: https://blog.zysicyj.top/categories/技术文章/后端技术/系列文章/面试题精讲/

本文由 mdnice 多平台发布

相关文章
|
3月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
JSON Java 数据格式
【Java反序列化】@JsonAlias字段别名
 @JsonAlias 是 Jackson 库提供的一个注解,用于在反序列化 JSON 数据时,为字段或方法指定多个可接受的名称或别名。
604 0
|
XML 存储 JSON
【面试题精讲】序列化协议对应于 TCP/IP 4 层模型的哪一层?
【面试题精讲】序列化协议对应于 TCP/IP 4 层模型的哪一层?
|
3月前
|
XML 存储 JSON
【IO面试题 六】、 除了Java自带的序列化之外,你还了解哪些序列化工具?
除了Java自带的序列化,常见的序列化工具还包括JSON(如jackson、gson、fastjson)、Protobuf、Thrift和Avro,各具特点,适用于不同的应用场景和性能需求。
|
3月前
|
JSON Java 数据格式
【IO面试题 七】、 如果不用JSON工具,该如何实现对实体类的序列化?
除了JSON工具,实现实体类序列化可以采用Java原生序列化机制或第三方库如Protobuf、Thrift、Avro等。
|
3月前
|
Java
JDK序列化原理问题之在JDK序列化中不同JDK版本字段不一致的情况如何解决
JDK序列化原理问题之在JDK序列化中不同JDK版本字段不一致的情况如何解决
|
XML JSON JavaScript
【面试题精讲】常见序列化协议有哪些?
【面试题精讲】常见序列化协议有哪些?
|
存储 缓存 Java
每日一道面试题之介绍一下Java的序列化和反序列化!
每日一道面试题之介绍一下Java的序列化和反序列化!
119 0
|
6月前
|
SQL 存储 安全
每日一道面试题:Java中序列化与反序列化
每日一道面试题:Java中序列化与反序列化
60 0
|
6月前
|
JSON Android开发 数据格式
android 使用GSON 序列化对象出现字段被优化问题解决方案
android 使用GSON 序列化对象出现字段被优化问题解决方案
117 0
下一篇
无影云桌面