- 浏览: 91529 次
- 性别:
- 来自: 上海
文章分类
最新评论
-
rihui1hao:
总的来说还是不错的
3、Session的get()/load( ...
hibernate总结 -
Jassicr:
相见恨晚呐
java常用算法分析和实现(一) -
xuhang1128:
这是我看过的最好的讲解jvm内存管理,谢谢lz
JVM内存管理:深入垃圾收集器与内存分配策略 -
zcr789654123:
...
StringUtils api 中文 英文 对照
1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;
2) 在网络上传送对象的字节序列。
1)Serializable接口可使类中的所有成员变量自动被序列化(transient和static修饰的变量除外),默认的
序列化方式会序列化整个对象图,这需要递归遍历对象图。如果对象图很复杂,递归遍历操作需要消耗很多
的空间和时间,它的内部数据结构为双向列表。在应用时,如果对某些成员变量都改为transient类型,将
节省空间和时间,提高序列化的性能。
2)Externalizable接口继承自Serializable接口,实现Externalizable接口的类完全由自身来控制序列化
的行为,即Externalizable对象默认情况下不保存任何它的字段,而仅实现Serializable接口的类可以
采用默认的序列化方式 。
那我们如何对一个Serializable对象的序列化和反序列化行为进行控制呢?
1)加transient修饰符,这样改变量就不会被序列化了
2)添加(不是“实现”和“重载” )writeObject和readObject方法: private void writeObject(ObjectOutputStream stream) throws IOException; private void readObject(ObjectOutputStream stream) throws IOException; 这样一旦对象被序列化或者被反序列化,就会自动分别调用这两个方法,而不会调用默认的序列化和反序列化方法。(这一点确实感觉有点奇怪,或者叫混乱!)
当ObjectOutputStream对一个Serializable对象进行序列化时,如果该对象具有writeObject()方法,那么就会执行这一方法,否则就按默认方式序列化。在该对象的writeObjectt()方法中,可以先调用ObjectOutputStream的defaultWriteObject()方法,使得对象输出流先执行默认的序列化操作。同理可得出反序列化的情况,不过这次是defaultReadObject()方法。
1) 创建一个对象输出流,它可以包装一个其他类型的目标输出流,如文件输出流;
2) 通过对象输出流的writeObject()方法写对象。
1) 创建一个对象输入流,它可以包装一个其他类型的源输入流,如文件输入流;
2) 通过对象输入流的readObject()方法读取对象。
下面是个简单的例子: import java.io.*; import java.util.Date; public class Test{ public static void main(String[] args) throws Exception { //序列化对象 ObjectOutputStream out = new ObjectOutputStream( new FileOutputStream("c:/objectFile.data")); MyObject obj1= new MyObject("liuhongliang", 24); out.writeObject("hello world!"); out.writeObject(new Date()); out.writeObject(obj1); out.writeInt(54); out.close(); //反序列化对象 ObjectInputStream in = new ObjectInputStream( new FileInputStream(("c:/objectFile.data")); System.out.println("obj1=" + (String) in.readObject()); System.out.println("obj2=" + (Date) in.readObject()); MyObject obj3 = (MyObject) in.readObject(); System.out.println("obj3=" + obj3); int obj4 = in.readInt(); System.out.println("obj4=" + obj4); in.close(); } } //自定义可序列化类 class MyObject implements Serializable { private String name; private int age; public MyObject(String name, int age) { this.name = name; this.age = age; } public String toString() { return "name=" + name + ", age=" + age; } }
关于serialVersionUID
在Loong(我们公司自己开发的基于OSGI的网络应用服务器平台)中集成Glassfish 的数据源时遇到了序列化的问题:在Glassfish中序列化的连接池对象,在Loong里面反序列化时总是不成功!后来查了相关资料,原来是连接池类出了问题:只实现了Serializable接口,没有指定具体的serialVersionUID。
凡是实现Serializable接口的类都应当有一个表示序列化版本标识符的静态变量:
类的serialVersionUID的默认值完全依赖于Java编译器的实现,对于同一个类,用不同的Java编译器编译,有可能会导致不同的serialVersionUID,也有可能相同。为了提高哦啊serialVersionUID的独立性和确定性,强烈建议 在一个可序列化类中显示的定义serialVersionUID,为它赋予明确的值。
显式地定义serialVersionUID有两种用途:
1) 在某些场合,希望类的不同版本对序列化兼容,因此需要确保类的不同版本具有相同的serialVersionUID;
2) 在某些场合,不希望类的不同版本对序列化兼容,因此需要确保类的不同版本具有不同的serialVersionUID。
上面的例子里,现将MyObject对象序列化到硬盘文件 c:/objectFile.data,然后反序列化之,这样可以实现深度复制,但是由于操作硬盘,所以当该操作比较频繁时会严重影响系统性能,上面是用文件流方式的实现,我们可以用字节流方式来高效的实现深度复制: import java.io.*; import java.util.Date; public class Test2 { public static void main(String[] args) throws Exception { //序列化对象 ObjectOutputStream out = new ObjectOutputStream( new ByteArrayOutputStream()); MyObject obj1= new MyObject("liuhongliang", 24); out.writeObject("hello world!"); out.writeObject(new Date()); out.writeObject(obj1); out.writeInt(54); out.close(); //反序列化对象 ObjectInputStream in = new ObjectInputStream( new ByteArrayInputStream(out.toByteArray())); System.out.println("obj1=" + (String) in.readObject()); System.out.println("obj2=" + (Date) in.readObject()); MyObject obj3 = (MyObject) in.readObject(); System.out.println("obj3=" + obj3); int obj4 = in.readInt(); System.out.println("obj4=" + obj4); in.close(); } } //自定义可序列化类 class MyObject implements Serializable { private String name; private int age; public MyObject(String name, int age) { this.name = name; this.age = age; } public String toString() { return "name=" + name + ", age=" + age; } }
发表评论
-
SAX,DOM,JAXP,JDOM,DOM4J比较
2010-11-17 18:26 1699第一:首先介绍一下SAX,DOM,JAXP,JDOM,DOM4 ... -
一次Java垃圾收集调优实战(转)
2010-11-13 18:52 6681 资料 JDK5.0垃圾收集优化之--Don't Pa ... -
编写对GC友好,又不泄漏的代码
2010-11-13 18:33 608作者:江南白衣,最新 ... -
JVM内存管理:深入垃圾收集器与内存分配策略(转)
2010-11-13 18:24 585概述: 说起垃圾收集(Garbage Collection ... -
JVM内存管理:深入Java内存区域与OOM(转)
2010-11-13 18:13 642Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的 ... -
java线程安全总结(转)
2010-11-13 17:46 719浅谈java内存模型 ... -
注解(Annotation)使用详解(转)
2010-11-13 15:33 640注解(Annotation) 为我们在代码中天界信息提供了一 ... -
java泛型总结2
2010-11-13 14:55 6331 Java 泛型设计中的一些 ... -
java泛型总结1
2010-11-13 14:54 767//泛型代码 public class Pair< ... -
java反射机制总结
2010-11-12 20:18 1207经过多方面的资料 ... -
java异常总结
2010-11-12 18:20 868本文重在Java中异常机制的一些概念。写本文的目的在于方便我很 ... -
java IO总结
2010-11-12 17:14 584Java 流在处理上分为字 ... -
java对String字符串对象的创建以及管理总结
2010-11-12 16:33 837经常看到很多人讨论java ... -
java集合框架总结
2010-11-12 16:13 8581、Java容器类库的 ... -
java内部类总结
2010-11-12 15:18 830内部类是指在一个外部类的内部再定义一个类。内部类作为外部类的一 ... -
JVM内存管理:深入垃圾收集器与内存分配策略
2010-11-12 14:12 900Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的 ... -
jdk1.5垃圾回收机制
2010-11-12 13:59 1165Java开发Server最大的障碍,就是JDK1.4版之前的的 ... -
垃圾回收算法总结
2010-11-12 13:09 473最近找工作,被问了2次 ... -
Java的垃圾回收总结
2010-11-12 12:55 705内存是稀缺的资源,哪怕内存一块钱一条!如果在编程中使用不当,再 ...
相关推荐
java序列化和反序列化java序列化和反序列化java序列化和反序列化
Xson是一个Java对象序列化和反序列化程序。支持Java对象到字节数组的序列化,和从字节数组到Java对象的反序列化。 Maven: <groupId>com.github.xsonorg</groupId> <artifactId>xson-core <version>1.0.1 ...
java 对象的序列化与反序列化 java 对象的序列化与反序列化
java反序列化工具,覆盖jboss、weblogic、websphere。
在应用java进行c-s开发的时候,尤其涉及到图片和视频之间的传输时,需要用序列化和反序列化技术,希望对您有帮助
java对象 java序列化 java反序列化
Java序列化与反序列化 Java序列化与反序列化 Java序列化与反序列化 Java序列化与反序列化 Java序列化与反序列化
java 的序列化与反序列化举例测试
java序列化(Serializable)的作用和反序列化.doc 有详细的讲解哦。 在什么地方用的到都有说明的.
java 常用序列化和反序列化框架使用demo ,java 常用序列化和反序列化框架使用demo
Java Json序列化与反序列化
序列化是干什么的? 简单说就是为了保存在内存中的各种对象的状态(也就是实例...虽然你可以用你自己的各种各样的方法来保 存object states,但是Java给你提供一种应该比你自己好的保存对象状态的机制,那就是序列化。
Java序列化和反序列化
java序列化和反序列化1
通过实现 Serializable 接口,Java对象可以被序列化和反序列化。序列化可以将对象转换为字节流,以便于存储或传输。反序列化则可以将字节流重新转换为原始对象。需要注意的是,序列化和反序列化的类必须具有相同的 ...
极好的序列化与发序列化代码。可以处理array集合,数组或者单个对象等的序列化与反序列化。
java序列化与反序列化
java反序列化工具;weblogic反序列化工具;jboss反序列化工具。