快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

关于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类,假如可以序列化,进行传输或者保存,也无法对他们进行重新的资源分配,而且,也是没有必要这样实现.
返回类别: 教程
上一教程: JSP与JAVAMAIL之4(发送HTML格式邮件)
下一教程: 关于JDK1.2的JDBC中文问题的解决

您可以阅读与"关于JAVA中的对象序列化"相关的教程:
· JAVA对象序列化(整理篇)
· JAVA对象序列化保存为XML文件的工具类
· JAVA对象序列化保存为XML文件的工具类
· java对象序列化学习笔记
· java中的对象引用问题的再次理解
    微笑服务 优质保证 索取样品