java中transient关键字分析
1、序列化、反序列化
序列化: 将对象的状态信息转换为可以存储或传输的形式的过程。
反序列化: 反序列化从序列化的表示形式中提取数据,并直接设置对象状态(赋值)。
2、作用
官方解释:Variables may be marked transient to indicate that they are not part of the persistent state of an object.
翻译过来:变量可以标记为瞬态,以指示它们不是对象持久状态的一部分。
transient 与类对象的序列化息息相关,序列化保存的是 类对象 状态。
被 transient 关键字修饰的成员变量,在类的实例化对象的序列化处理过程中会被忽略。
因此,transient 变量不会贯穿对象的序列化和反序列化。
3、修饰范围
transient 只能修饰成员变量。
4、使用场景
用户姓名、密码、卡号等敏感信息不想被传输。
User 类
public class User implements Serializable { /** * 用户ID */ private Long id; /** * 年龄 */ private Integer age; /** * 用户姓名 */ private transient String name; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "User{" + "id=" + id + ", age=" + age + ", name='" + name + '\'' + '}'; } }
import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; public class UserTest { public static void main(String[] args) { User liSi = new User(); liSi.setId(1000000001L); liSi.setAge(18); liSi.setName("liSi"); System.out.println(liSi); try (ObjectOutputStream outputStream = new ObjectOutputStream(new FileOutputStream("liSi.txt"))) { outputStream.writeObject(liSi); } catch (Exception ignore) {} try (ObjectInputStream inputStream = new ObjectInputStream(new FileInputStream("liSi.txt"))) { liSi = (User) inputStream.readObject(); } catch (Exception ignore) {} System.out.println(liSi); } }
输出结果:
User{id=1000000001, age=18, name='liSi'}
User{id=1000000001, age=18, name='null'}
5、注意
transient 只有在类实现了 Serializable 接口才能起作用。如果把 User 类去除实现 Serializable。
则输出结果就会变成:
输出结果:
User{id=1000000001, age=18, name='liSi'}
User{id=1000000001, age=18, name='liSi'}
到此这篇关于java中transient关键字分析的文章就介绍到这了,更多相关java的transient内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
@PathVariable和@RequestParam传参为空问题及解决
这篇文章主要介绍了@PathVariable和@RequestParam传参为空问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-11-11SpringBoot中使用SpringSecurity进行权限控制的示例代码
本文将详细介绍如何在Spring Boot应用程序中使用Spring Security进行权限控制,我们将探讨Spring Security的基本概念,以及如何使用Spring Security实现认证和授权,需要的朋友可以参考下2024-02-02SpringBoot+Redis防止恶意刷新与暴力请求接口的实现
这篇文章主要为大家介绍了如何利用springboot和Redis来实现防止恶意刷新与暴力请求接口,文中的示例代码讲解详细,需要的可以参考一下2022-06-06重新启动IDEA时maven项目SSM框架文件变色所有@注解失效
这篇文章主要介绍了重新启动IDEA时maven项目SSM框架文件变色所有@注解失效,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-03-03Springboot 如何指定获取出 yml文件里面的配置值
这篇文章主要介绍了Springboot 如何指定获取出 yml文件里面的配置值操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-07-07
最新评论