序列化与反序列化
序列化与反序列化
本文来自 KyleWong123 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/qq_39162216/article/details/82720568?utm_source=copy
一、什么是序列化与反序列化?
序列化:将堆中的java对象变成字节流的形式传出去的过程;即将数据结构或者java对象转化成二进制串的过程;
反序列化:把一个字节流文件恢复成java对象的过程;即将序列化生成的二进制串转换成数据结构或者java对象的过程。
二、为什么要序列化?
1.在分布式系统中,需要将对象在网络上传输,就得将数据转换成二进制串的形式(比如需要共享的javaBean对象,就要实现序列化);
2.节省服务器内存;
三、如何实现序列化?
1.需要序列化的对象,必须实现java.io.Serializable接口(比如String、Integer);
2.在java中使用对象流实现序列化与反序列化:
ObjectOutputStream:通过 writeObject()方法做序列化操作
ObjectInputStream:通过 readObject() 方法做反序列化操作
四、注意
如果某些属性不需要实现序列化,咋可在属性前加 transient 修饰
private String name;//需要序列化
transient private int age;//不需要序列化
还没有评论,来说两句吧...