对象序列化与反序列化

目录

序列化

反序列化

ObjectOutputStream

ObjectInputStream


序列化


一个类必须实现了Serializable 接口,其对象才能序列化,Serializable接口没有方法或字段,用于标识类的唯一性.

反序列化

从文件(字节码)获取到对象内容.

ObjectOutputStream

对象输出流.通过使用流中的文件可以实现对象的持久存储.
1.构造器
ObjectOutputStream(OutputStream out) //传入一个文件流,用于存储对象
2.主要方法
public final void writeObject(Object obj) throws IOException
当 OutputStream 中出现问题或者遇到不应序列化的类时,将抛出异常。

ObjectInputStream


对ObjectOutputStream写入的数据和对象进行反序列,恢复以前那些以前序列的对象
1.构造器
public ObjectInputStream(InputStream in)throws IOException //创建从指定 InputStream 读取的 ObjectInputStream。
2.主要方法
public final Object readObject() throws IOException,ClassNotFoundException //从 ObjectInputStream 读取对象
当 InputStream 中出现问题或者遇到不应反序列化的类时,将抛出异常。

测试类

package Io;

import ArrayList.User;

import java.io.*;

public class ObjectStream {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        //对象序列化
        OutputStream out=new FileOutputStream("D://tep.txt");
        ObjectOutputStream outs=new ObjectOutputStream(out);
        People p=new People(22,"张修");
        outs.writeObject(p);
        //对象反序列化
        InputStream in=new FileInputStream("D://tep.txt");
        ObjectInputStream ins=new ObjectInputStream(in);
        People p1=(People)ins.readObject();
        System.out.println(p1);
    }
}

People类

package Io;

import java.io.Serializable;

public class People implements Serializable {
    String name;
    int age;

    public People(int age,String name) {
        this.age = age;
        this.name=name;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }

    @Override
    public String toString() {
        return "People{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

对象序列化与反序列化

 

上一篇:值校验、范围校验、长度校验、格式校验


下一篇:Spark3教程(六)IDEA下Java开发Spark SQL