目录
1.对象的输入输出流
也被称为对象的序列化与反序列化操作,被序列化的对象必须满足两个条件
1)实现Serializable接口:Serializable 是一个标记接口,不实现此接口的类将不会使任何状态序列化或反序列化,会抛出 NotSerializableException
2)这个类的所有属性都必须是可序列化的。如果某个属性不需要被序列化,可以将该属性注明是瞬态,使用transient关键字标识
注意:
序列化一个对象时,要求它的属性要么是基本数据类型,如果是引用数据类型,这个引用数据类型也必须实现Serializable接口。
序列化一个数组,要求元素类型实现Serializable接口。
1.1 ObjectOutputStream
对象的输出流。对象的输出流将指定的对象写入到文件的过程,对象信息一旦写到文件上,对象信息就看做持久化了,这个过程也叫对象序列化的过程
1.2 ObjectInputStream
对象的输入流。对象的输入流将指定序列化号的文件读取出来的过程,就是对象的反序列化的过程
@Data
public class User implements Serializable {
private static final long serialVersionUID=1000L;
private int userId;
private String name;
private int age;
private String sex;
private transient String address;
}
public class TestMain {
public static void writeUser() {
try {
User user = new User();
user.setUserId(1);
user.setName("李三思");
user.setAddress("北京市");
// 创建objectOutputStream对象,构造方法中传递字节输出流
ObjectOutputStream outputStream = new ObjectOutputStream(
new FileOutputStream("xx.json"));
// 使用objectOutputStream对象中的writeObject,将对象写入文件中
outputStream.writeObject(user);
System.out.println("java 序列化成功");
// 释放资源
outputStream.close();
} catch (Exception e) {
System.out.println("writeUser: " + e.getMessage());
}
}
public static void readUser() {
User user;
try {
ObjectInputStream inputStream = new ObjectInputStream(new FileInputStream("xx.json"));
user = (User) inputStream.readObject();
System.out.println("反序列化成功");
System.out.println("用户id:" + user.getUserId());
System.out.println("用户名称:" + user.getName());
System.out.println("用户住址:" + user.getAddress());
} catch (Exception e) {
System.out.println("readUser: " + e.getMessage());
}
}
public static void main(String[] args) {
writeUser();
readUser();
}
}
输出(由于address字段被transient关键字标识,表示不需要持久化,所以后面读取的时候该字段值也是空)