服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

关于java中的对象序列化


  java对象序列化机制一般来讲有两种用途:
  
    1.需要将对象的状态保存到文件中,而后能够通过读入对象状态来重新构造对象,恢复程序状态。
  
    2.使用套接字在网络上传送对象的程序来说,是很有用的。
  
    我们通过让类实现java.io.serializable 接口可以将类序列化。这个接口是一个制造者(marker)接口。也就是说,对于要实现它的类来说,该接口不需要实现任何方法。它主要用来通知java虚拟机(jvm),需要将一个对象序列化。
  
    对于这个,有几点我们需要明确:
  
    1.并非所有类都可以序列化,在cmd下,我们输入serialver java.net.socket,可以得到socket是否可序列化的信息,实际上socket是不可序列化的。
  
    2.java有很多基础类已经实现了serializable接口,比如string,vector等。但是比如hashtable就没有实现serializable接口。
  
    将对象读出或者写入流的主要类有两个: objectoutputstream与objectinputstream 。objectoutputstream 提供用来将对象写入输出流的writeobject方法, objectinputstream提供从输入流中读出对象的readobject方法。使用这些方法的对象必须已经被序列化的。也就是说,必须已经实现serializable接口。如果你想writeobject一个hashtable对象,那么,会得到一个异常。
  
    下面举个例子:
  
  import java.io.*;
  
  public class testser implements serializable {
   public int ii;
  
   testser()
   {
  
   }
  
   testser( int param )
   {
   ii = param;
   }
  }
  
  
  
    testser是一个实现了serializable接口的类。
  
    读写这个序列化过的类:
  
  import java.io.*;
  
  public class ser {
  
   private static string datafile;
   datafile="ser.data";
  
   public static void main( string[] argv )
   {
   system.out.println( "java serialization demo." );
   serdata data;
   try {
   objectinputstream in = new objectinputstream
   ( new fileinputstream( datafile ));
   data = (serdata) in.readobject();
   in.close();
   }
   catch (exception e) {
   data = new testser();
   }
   system.out.println( "original data: ii = " + data.ii );
   data.ii++;
   try {
   objectoutputstream out = new objectoutputstream
   ( new fileoutputstream( datafile ) );
   out.writeobject( data );
   out.flush();
   out.close();
   }
   catch (exception e) {
   system.out.println( e );
   }
   }
  }
  
  
  
    还有可以通过套接字传递序列化对象,大概类似。
  
    看到这里或许很多人都会有个疑问,是否所有的对象都可以序列化呢?
  
    当然是不可以的了,至于为什么不可以,那就有很多原因了,比如:
  
    1.安全方面的原因,比如一个对象拥有private,public等field,对于一个要传输的对象,比如写到文件,或者进行rmi传输等等,在序列化进行传输的过程中,这个对象的private等域是不受保护的.
  
    2.资源分配方面的原因,比如socket,thread类,如果可以序列化,进行传输或者保存,也无法对他们进行重新的资源分配,而且,也是没有必要这样实现.

扫描关注微信公众号