java 序列化
2015-07-23 18:41
351 查看
对象序列化,除了基本类型外,还有三种String,Enum,以及实现了Serializable接口的对象
我们使用ObjectInputStream和ObjectOutputStream进行相关的操作
考虑到序列化经常是为了在分布式通信中使用,故序列化后的空间大小是一个很重要的因素
使用java序列化时可以通过如下内容减少空间
1、序列化的对象尽量不存在继承关系
2、对象名字尽量短
3、变量使用基本类型
4、尽量不要序列化stream或者class
关于序列化有些注意:
1、对于同一个对象只会有一份数据被保存,其它都是保存的这个对象的引用
Object obj =new Object();
obj.setId(1);
ObjectOutputStream.write(obj);
obj.setId(2);
ObjectOutputStream.write(obj);
虽然write了两次,并且第二次的id=2.但是反序列化后的结果两个对象的内容是一样的,id都是1
2、序列化ID会被保存,不管你在对象中加不加,故对于要序列化的对象因该加上,防止反序列化时出现问题
3、对象中的静态变量不会被序列化
4、子类继承Serializable,其超类没有,则需要实现默认构造函数,并且超类中的变量值不会被序列化(都为默认值如:int i=2; String str=’hello’ 则序列化后的结果为i=0,str=null)
我们使用ObjectInputStream和ObjectOutputStream进行相关的操作
考虑到序列化经常是为了在分布式通信中使用,故序列化后的空间大小是一个很重要的因素
使用java序列化时可以通过如下内容减少空间
1、序列化的对象尽量不存在继承关系
2、对象名字尽量短
3、变量使用基本类型
4、尽量不要序列化stream或者class
关于序列化有些注意:
1、对于同一个对象只会有一份数据被保存,其它都是保存的这个对象的引用
Object obj =new Object();
obj.setId(1);
ObjectOutputStream.write(obj);
obj.setId(2);
ObjectOutputStream.write(obj);
虽然write了两次,并且第二次的id=2.但是反序列化后的结果两个对象的内容是一样的,id都是1
2、序列化ID会被保存,不管你在对象中加不加,故对于要序列化的对象因该加上,防止反序列化时出现问题
3、对象中的静态变量不会被序列化
4、子类继承Serializable,其超类没有,则需要实现默认构造函数,并且超类中的变量值不会被序列化(都为默认值如:int i=2; String str=’hello’ 则序列化后的结果为i=0,str=null)
相关文章推荐
- Java对象序列化与反序列化
- 序列化与反序列化
- java序列化和反序列化
- 一个完全打印出xml文档的程序 [我真是无聊]
- 谈论高并发(三十)解析java.util.concurrent各种组件(十二) 认识CyclicBarrier栅栏
- JAVA测试初看。
- javah 命令找不到类文件的解决办法
- Java clone方法(下)
- ***JAVA多线程的应用场景和应用目的举例
- ***Java多线程发展简史
- Caused by: java.lang.NoClassDefFoundError: Could not initialize class
- 使用eclips发展java当闪回的问题
- Java序列化与反序列化
- java视频教程每一张都讲的很细
- 查看eclipse ADT SDK JDK版本号
- 分析java CPU消耗
- Java基础——原码, 反码, 补码 详解
- eclipse中SVN分支合并到主干
- java.net.NoRouteToHostException: No route to host
- 通用 Java 文件上传和下载组件的设计与实现