关于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 );

}

}

}

还有可以通过套接字传递序列化对象,大概类似,不再赘述。

posted @   MichaelMaDragon  阅读(186)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示