Java中序列化是指将对象转换成字节序列的形式表示,这些字节序列包含了对象的数据和信息,序列化后的对象可以被写到数据库或文件中,也可以用于网络传输,Java序列化需要实体类实现Serializable接口。序列化后的字节序列可以恢复成Java对象,这个过程称为反序列化。
在实际开发过程中,对象的一些属性需要被序列化,另外一些不需要被序列化,比如用户的依稀敏感信息(如:密码,银行卡号等),为了安全起见,不希望在网络传输,这些字段的生命周期存在于调用者的内存中,不会被持久化或网络传输。Java中transient关键字可让这些被修饰的属性不被序列化。
注意事项:
- transient关键字只能修饰变量,不能修饰方法和类
- 静态变量不管是否被transient修饰,均不能被序列化
使用示例:
public class TestTransient {
@Data
public static class Cat {
public static String type = "hehehe";
private String name;
private Integer age;
private transient Integer sex;
public Cat() {
}
public Cat(String name, Integer age, Integer sex) {
this.name = name;
this.age = age;
this.sex = sex;
}
}
public static void main(String ... args) {
Cat cat = new Cat("Jerry", 1, 1);
System.out.println(cat);
Cat serialCat = JSON.parseObject(JSON.toJSONString(cat), Cat.class);
System.out.print(serialCat);
}
}
输出:
TestTransient.Cat(name=Jerry, age=1, sex=1)
TestTransient.Cat(name=Jerry, age=1, sex=null)