JAVAEE第十六篇-Serializable序列化

概念

序列化:将对象转换成二进制序列,能够存储到硬盘上
反序列化:将二进制序列转成对象.

序列化的作用

例如在Web的数据传输过程中,都是以二进制序列传输的,JVM接收到的都是二进制序列,只是JVM帮我们把二进制序列转换成了对象.但有些情况,例如tomcat存储Session的过程中,如果有十万个用户并发访问,这个时候我们如果把这么多的session对象都放入内存开销太大,这个时候可以利用序列化,将session进行二进制序列存储到硬盘中,当用的时候再获取.

序列化代码实现

  • 定义序列化对象
public class Person implements Serializable{
        public  static final long serialVersionUID = 1L;
        private String name;
        private int age;
        public Person(String name, int age) {
            this.name = name;
            this.age = age;
        }
        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public int getAge() {
            return age;
        }

        public void setAge(int age) {
            this.age = age;
        }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}
  • 实现序列化和反序列化
public class SerializableDemo {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        //序列化,文件输出流指的是JVM向外输出,由输出流写入本地文件
        FileOutputStream fileOutputStream = new FileOutputStream("out.text");
        ObjectOutputStream objectOutputStream = new ObjectOutputStream(fileOutputStream);
        Person person = new Person("张三", 10);
        objectOutputStream.writeObject(person);
        objectOutputStream.close();

        //反序列化
        FileInputStream fileInputStream = new FileInputStream("out.text");
        ObjectInputStream objectInputStream = new ObjectInputStream(fileInputStream);
        Object o = objectInputStream.readObject();
        System.out.println(o);
    }
}
发布了46 篇原创文章 · 获赞 4 · 访问量 7106
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览