`
superseven
  • 浏览: 107995 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Java序列化(一)

 
阅读更多
1、前言

      序列化的过程就是对象写入字节流和从字节流中读取对象。将对象状态转换成字节流之后,将其保存到文件中,管道到另一线程中或通过网络连接将对象数据发送到另一主机。对象序列化功能非常简单、强大,在RMI、Socket、JMS、EJB都有应用。对象序列化问题在网络编程中并不是最激动人心的课题,但却相当重要,具有许多实用意义。  

2、Java序列化的实质

     java序列化只是序列化对象属性的值,而不会去序列化方法,因为方法是不带状态,就是一些指令,指令是不需要序列化的,只要你的JVM classloader可以load到这个类那么类方法自然就可以获得。序列化真正需要保存的知识对象属性的值和对象的类型。我们可以通过以下几个例子去了解Java的序列化。

Class DomainObject:

package test;

import java.io.Serializable;

public class DomainObject  implements Serializable {

 private String name;
 
 private int age ;

 public int getAge(); {
  return age;
 }

 public void setAge(int age); {
  this.age = age;
 }

 public String getName(); {
  return name;
 }

 public void setName(String name); {
  this.name = name;
 }
}

Class Main:

package test;

import java.io.FileOutputStream;
import java.io.ObjectOutputStream;

public class Main {

 public static void main(String[] args) throws Exception {
  DomainObject obj = new DomainObject();
  obj.setAge(29);
  obj.setName("test");
  FileOutputStream fos = new FileOutputStream("d:/DomainObject");
  ObjectOutputStream oos = new ObjectOutputStream(fos);;
  oos.writeObject(obj);
  oos.close();
  fos.close();
 }
}

DomainObject是我们准备序列化的类,而Main则是将实例化一个DomainObject对象在赋值后序列化到硬盘中。执行后我们可以在D盘的目录下找到DomainObject的一个文件,用UltraEdit打开可以看到以下内容:
test. DomainObject
ageL
namet
Ljava/lang/String;xp
test

这些信息告诉我们在序列化的时候保存了哪些内容:
1)对象的类型
2)对象属性的类型
3)对象属性的值
所有注意的几点:
a)、当一个对象被序列化的时候,只保存对象的非静态成员变量,而不会保存任何成员方法和静态成员变量。
b)、如果一个成员变量是一个对象,那么这个对象的成员变量也会被保存。
c)、如果一个可序列化的对象对某个不可序列化的对象进行引用,那么整个序列化操作将会失败,并且会抛出一个NotSerializableException 我们可以引用标记transient,那么对象任然可以序列化,transient还可以用来标记不希望序列化的数据。

3、Java序列化的实现
      一般而言java的序列化只要实现java.io.Serializable接口即可。该接口是一个标记式,本身不包含任何内容,实现该接口则表示这个类准备支持序列化的功能。
     序列化的机制是通过java.io.ObjectOutPutStream和java.io.ObjectInputStream类来实现的。在序列化的时候,会先实例化一个ObjectOutPutStream对象,然后调用writeObject()方法;在反序列化的时候,则会实例化一个ObjectInputStream对象,然后调用其readObject()方法。
     JVM有一个预定义的序列化实现机制,即默认调用 ObjectOutputStream.defaultWriteObject() 和ObjectInputStream.defaultReadObject() 来执行序列化操作。如果想自定义序列化的实现,则必须在声明了可序列化的类中实现writeObject()和readObject()方法。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics