序列化与反序列化
定义:
1)序列化:把字段转化为可传输的字节序列的过程;
2)反序列化:把字节序列转化为对象的过程;
为什么要序列化:
为了对象可以跨平台存储和进行网络传输,我们进行跨平台存储和网络存储的方式方式就是IO,而我们IO支持的数据格式就是字节数组,因为我们单方面的只把对象转化为字节数组还不行,因为没有规则的字节数组我们是没有办法将其还原回来的,所以我们在把对象转化为字节数组的时候就应该确定一种规范,那么我们就可以在需要的时候将其反序列化解析成对象;
序列化的方式:
1)JDK(实现Serializable接口,个接口非常特殊,没有任何方法,只起标识作用.Java序列化保留了对象类的元数据(如类、成员变量、继承类信息等),以及对象数据等,兼容性最好,但不支持跨语言,而且性能一般。)
2)JSON:是一种轻量级的数据交换格式。 JSON 序列化就是将数据对象转换为 JSON 字符串。在序列化过程中抛弃了类型信息,所以反序列化时只有提供类型信息才能准确地反序列化。
Java序列化常见的问题:
1)static 属性不能被序列化(序列化保存的是对象的状态,静态变量属于类的状态,因此 序列化并不保存静态变量。)
2)Transient 属性不会被序列化
3)所有实现序列化的对象都必须要有个版本号,这个版本号可以由我们自己定义,当我们没定义的时候JDK工具会按照我们对象的属性生成一个对应的版本号。
序列化与反序列化
于 2022-10-18 12:00:03 首次发布