Java序列化

1.java序列化与反序列化的概念

  • 序列化
    将数据结构或者对象转化为二进制的过程
  • 反序列化
    将在序列化过程中生成的二进制转化为数据结构或者对象的过程
  • 持久化
    把数据结构或者对象存储起来 比如:硬盘

序列化方案:
1.Serializable Java的序列化方案
2.Parcelable Android独有
3.json xml protbuf ... 广义的序列化

2.Serializable接口及使用实例

1.Serializable是一个接口

public interface Serializable { 

} 
  • Serializable序列化
 /**
     * 序列化对象 ** @param obj * @param path * @return
     */
    synchronized public static boolean saveObject(Object obj, String path) {
        if (obj == null) {
            return false;
        }
        ObjectOutputStream oos = null;
        try {
            // 创建序列化流对象 
            oos = new ObjectOutputStream(new FileOutputStream(path));
            //序列化
            oos.writeObject(obj);
            oos.close();
            return true;
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if (oos != null) {
                try {
                    // 释放资源
                    oos.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        return false;
    }
  • Serializable反序列化
 synchronized public static <T> T readObject(String path) {
        ObjectInputStream ojs = null;
        try {
            // 创建反序列化对象 
            ojs = new ObjectInputStream(new FileInputStream(path));
            // 还原对象
            return (T) ojs.readObject();
        } catch (IOException | ClassNotFoundException e) {
            e.printStackTrace();
        } finally {
            if (ojs != null) {
                try {// 释放资源
                    ojs.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        return null;
    }

2.Externalizable 是Serializable的一个子类

public interface Externalizable extends Serializable { 
    void writeExternal(ObjectOutput var1) throws IOException; 
    void readExternal(ObjectInput var1) throws IOException, 
}

3.序列化面试常见问题

  1. 什么是SerialVersionUID?如果不定义这个,会发生什么?
    序列化对象的版本号
    如果修改序列化对象的数据,可能会导致异常
    2.序列化时,如何不序列化某些变量不序列化
    transient 关键字
    3.如果对象没有实现Serializable接口,去序列化会出现什么情况?
    会报错 NoSerializableException

4.序列化源码流程解析


序列化流程
判断对象中是否写了readObject和writeObject

5.android的Parcelable相关概念

Binder通信机制

6.Parcelable与Serializable的性能比较

  • Serializable性能分析
    Serializable是Java中的序列化接口,其使用起来简单但开销较大(因为Serializable在序列化过程中使
    用了反射机制,故而会产生大量的临时变量,从而导致频繁的GC),并且在读写数据过程中,它是通
    过IO流的形式将数据写入到硬盘或者传输到网络上。
  • Parcelable性能分析
    Parcelable则是以IBinder作为信息载体,在内存上开销比较小,因此在内存之间进行数据传递时,推荐使用Parcelable,而Parcelable对数据进行持久化或者网络传输时操作复杂,一般这个时候推荐使用


    Parcelable与Serializable比较
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 序列化:将数据结构或者对象转换成二进制串的过程。 反序列化:将序列化生成的二进制串转换成数据结构或者对象的过程 应...
    森屿暖茶阅读 1,365评论 0 1
  • 基本概念 序列化就是把一个Java对象变为字节序列(byte[]数组)的过程。反序列化其实就是把一个字节序列变回J...
    下雨天不带伞boy阅读 1,592评论 0 0
  • Android序列化 目标 为什么序列化 序列化的定义 Serializable的使用和原理 Parcelable...
    Heezier阅读 3,477评论 0 1
  • 题外话:从事IT要学习的东西太多了,有时候会比较浮躁,因为要学的东西太多但又无从下手,甚至有很多基础都还没有深入学...
    Garwer阅读 4,206评论 2 9
  • 1.背景 某天,我在写代码定义 bean 的时候,顺手写了个 public class User implemen...
    李眼镜阅读 4,151评论 0 2