1. 序列化
Java中对象的序列化指的是将对象转换成以字节序列的形式来表示,这些字节序列包含了对象的数据和信息,一个序列化后的对象可以被写到数据库或文件中,也可用于网络传输。一般地,当我们使用缓存cache(内存空间不够有可能会本地存储到硬盘)或远程调用rpc(网络传输)的时候,经常需要让实体类实现Serializable接口,目的就是为了让其可序列化。当然,序列化后的最终目的是为了反序列化,恢复成原先的Java对象实例。所以序列化后的字节序列都是可以恢复成Java对象的,这个过程就是反序列化。
transient是Java语言的关键字,用来表示一个成员变量不是该对象序列化的一部分。当一个对象被序列化的时候,transient型变量的值不包括在序列化的结果中。而非transient型的变量是被包括进去的。 注意static修饰的静态变量天然就是不可序列化的。
2.直接上测试结果
实现序列化可以正常本地存储及反序列化
@Data
public class User implements Serializable {private String name;private String sex;private transient String hobby;private static String idCard=******";
}User user=new User();
user.setName("admin");
user.setSex("男");
user.setHobby("eat");
// 把对象写到文件中
try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("/../user.txt"))){oos.writeObject(vo2);
} catch (IOException e) {e.printStackTrace();
}// 从文件中读出对象
try (ObjectInputStream ois = new ObjectInputStream(new FileInputStream(new File("/../user.txt")))){User userRead = (User) ois.readObject();System.out.println(userRead);} catch (IOException | ClassNotFoundException e) {e.printStackTrace();
}
2.反例测试结果
去掉User的序列化,执行写入报错
@Data
public class User {private String name;private String sex;private transient String hobby;private static String idCard=******";
}User user=new User();
user.setName("admin");
user.setSex("男");
user.setHobby("eat");
// 把对象写到文件中
try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("/../user.txt"))){oos.writeObject(vo2);
} catch (IOException e) {e.printStackTrace();
}
java.io.NotSerializableException: cn.**.User
at java.io.ObjectOutputStream.writeObject0(ObjectOutputStream.java:1184)
at java.io.ObjectOutputStream.writeObject(ObjectOutputStream.java:348)
at cn.***.TestAction.main(TestAction.java:66)