专栏首页Happy的分享Java中的transient关键字

Java中的transient关键字

前言

之前写过一篇序列化相关的文章,今天要讲的这个文件自transient也是跟序列化有关系的。但是,挺多人没有了解过该关键字甚至是不知道该关键字的存在。

transient关键字介绍

在Java中,当一个类实现了java.io.Serializable接口,即表明了该类可以被序列化。我们可以把该类的属性序列化然后保存在外部,或者跟另外一个jvm进行数据传递。但是,我们是否想过,如果一个类包含隐私信息,如用户的密码等,那么这个属性就不能够被序列化到外部。当然,我们可以在序列化之前手动set该值为null,但是最优雅的做法就是使用transient关键字。

在我们不想序列化到外部的属性前面加上transient关键字,该属性将不会被序列化。

代码测试

假设我们有User对象如下:

@Data
public class User implements Serializable {

    private String username;

    private transient String password;

}
复制代码

通过序列化工具类序列化和反序列化:

@Test
public void test() {
    User user = new User();
    user.setUsername("happyjava");
    user.setPassword("123456");
    System.out.println("序列化之前:" + user.toString());
    byte[] serialize = SerializationUtils.serialize(user);
    User newUser = SerializationUtils.deserialize(serialize);
    System.out.println("反序列化:" + newUser);
}
复制代码

运行结果如下:

通过结果可以看到,反序列化之后没有存在password字段,这反向的证明了序列化的时候没有把password参与到序列化中去。这正是transient关键字的用处。

静态属性序列化问题

可能有读者会想到,如果静态属性加上transient会怎么样?反序列化回来之后是不是该类的静态属性就编程null了?下面通过代码来验证下:

给User添加属性count:

  private transient static int count;
复制代码

这是一个静态属性。

先把该属性设置为10,然后序列化、反序列化一个类,再查看该静态属性:

    @Test
    public void test() {
        User user = new User();
        User.setCount(10);
        user.setUsername("happyjava");
        user.setPassword("123456");
        System.out.println("序列化之前:" + user.toString());
        System.out.println("user count:"+User.getCount());
        byte[] serialize = SerializationUtils.serialize(user);
        User newUser = SerializationUtils.deserialize(serialize);
        System.out.println("反序列化:" + newUser);
        System.out.println("user count:" + User.getCount());
    }
复制代码

输出结果如下:

从结果看,静态属性没有发生改变。其实,不管有没有加transient关键字,静态属性都不会被序列化。

总结

1)一旦变量被transient修饰,变量将不再是对象持久化的一部分。

2)transient关键字只能修饰变量,而不能修饰方法和类。

3)被transient关键字修饰的变量不再能被序列化,一个静态变量不管是否被transient修饰,均不能被序列化。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 为什么阿里Java规约要求谨慎修改serialVersionUID字段

    serialVersionUID是在Java序列化、反序列化对象时起作用的一个字段。Java的序列化机制是通过判断类的serialVersionUID来验证版本...

    Happyjava
  • 【快学springboot】4.接口参数校验

    在开发接口的时候,参数校验是必不可少的。参数的类型,长度等规则,在开发初期都应该由产品经理或者技术负责人等来约定。如果不对入参做校验,很有可能会因为一些不合法的...

    Happyjava
  • 【快学springboot】7.使用Spring Boot Jpa

    Jpa (Java Persistence API) 是 Sun 官方提出的 Java 持久化规范。它为 Java 开发人员提供了一种对象/关联映射工具来管理 ...

    Happyjava
  • Java--序列化知识点

    今天线上遇到了DTO类实现了Serializable接口,但是其并没有显示声明serialVersionUID,这样的话每次打包有改动JDK就会为其重新生成se...

    屈定
  • 关于Java序列化你应该知道的一切

    什么是序列化 我们的对象并不只是存在内存中,还需要传输网络,或者保存起来下次再加载出来用,所以需要Java序列化技术。 Java序列化技术正是将对象转变成一串由...

    Java技术栈
  • Java 序列化机制

    1、一般情况下,只有当 JVM 处于运行时,Java 对象才可能存在,即这些对象的生命周期不会比 JVM 的生命周期更长。但在现实应用中,就可能要求在 JVM ...

    JMCui
  • Java序列化连环炮:是什么?为什么需要?如何实现?

    遇到这个 Java Serializable 序列化这个接口,我们可能会有如下的问题

    用户4143945
  • Java--序列化对象

    Java序列化是指把Java对象转换为二进制字节码并持久化到磁盘上的过程,Java反序列化是指把二进制码重新从磁盘读取并转换成Java对象的过程。

    SuperHeroes
  • 数据序列化的那些事

    为什么需要数据序列化呢?因为数据要“传输”,比如将数据网络通信传递给其他服务器,或者持久化到磁盘。那么传输为什么需要序列化呢?因为在内存中的数据,当前进程是知道...

    luoxn28
  • Python学习笔记 --- 序列化Serialization

    序列化 (serialization) 序列化是将对象状态转换为可保持或传输的格式的过程。与序列化相对的是反序列化,

    用户2398817

扫码关注云+社区

领取腾讯云代金券

玩转腾讯云 有奖征文活动