一、什么是java序列化和反序列化
序列化就是把对象改成二进制的过程,可以保存到磁盘或者网络发送,已达到以后恢复成原来的对象。序列化机制使得对象可以脱离程序的运行而独立存在。
反序列化就是从IO流中恢复对象。
二、实现序列化
//序列化步骤:
//步骤一:创建一个ObjectOutputStream输出流;
//步骤二:调用ObjectOutputStream对象的writeObject输出可序列化对象。
public class Person implements Serializable {
private static final long serialVersionUID = 1L;
private String name;
private int age;
//我不提供无参构造器
public Person(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
public class WriteObject {
public static void main(String[] args) throws ClassNotFoundException, IOException {
Person person = new Person("wang",11);
ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("person.txt"));
objectOutputStream.writeObject(person );
objectOutputStream.close();
}
}
//反序列化步骤:
//步骤一:创建一个ObjectInputStream输入流;
//步骤二:调用ObjectInputStream对象的readObject()得到序列化的对象
public class WriteObject {
public static void main(String[] args) throws ClassNotFoundException, IOException {
ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("person.txt"));
Person person= (Person ) objectInputStream.readObject();
System.out.println(person);
objectInputStream.close();
}
}
三、序列化有什么作用
- 方便传输,速度快,还很安全,被调用方序列化,调用方反序列化即可拿到传输前最原始的java对象,常用于不同进程之间的对象传输
- 方便存储,不管是存储成文件还是数据库,都行,存储为文件,下回要用可以直接反序列拿到对象
四、如果希望某些变量不序列化,该怎么做。
- 变量声明成静态变量(static)
- 变量声明成瞬态变量(transient )