序列化实现“轻量级的persistence”
主要是用于两方面:
1. RMI,远程传递对象
2. JavaBean,Bean的状态信息通常是在设计时配置的。这些状态信息必须保存起来,供程序启动的时候用。
Java中实现序列化,只要implements接口即可,代码如下:
[b]上述代码实现了对MakeObjectFile类的对象的序列化,并将序列化后的byte流保存在makeobj.obj文件中。[/b]
下面读取:makeobj.obj文件中的字节流读出,然后还原成对象,并调用其方法获得输出,代码如下:
主要是用于两方面:
1. RMI,远程传递对象
2. JavaBean,Bean的状态信息通常是在设计时配置的。这些状态信息必须保存起来,供程序启动的时候用。
Java中实现序列化,只要implements接口即可,代码如下:
package mySerializable;
import java.io.FileOutputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
public class MakeObjectFile implements Serializable {
private String str = new String();
public String getStr() {
return str;
}
public void setStr(String str) {
this.str = str;
}
public static void main(String[] args) {
try {
/*创建输出流*/
FileOutputStream objFile = new FileOutputStream("makeobj.obj");
ObjectOutputStream p = new ObjectOutputStream(objFile);
/*创建一个MakeObjectFile对象*/
MakeObjectFile mof = new MakeObjectFile();
mof.setStr("XiaoXiao");
p.writeObject(mof);
p.flush();
objFile.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
[b]上述代码实现了对MakeObjectFile类的对象的序列化,并将序列化后的byte流保存在makeobj.obj文件中。[/b]
下面读取:makeobj.obj文件中的字节流读出,然后还原成对象,并调用其方法获得输出,代码如下:
package mySerializable;
import java.io.FileInputStream;
import java.io.ObjectInputStream;
public class OpenObjectFile {
public static void main(String[] args) {
try {
/*创建输出流*/
FileInputStream objFile = new FileInputStream("makeobj.obj");
ObjectInputStream q = new ObjectInputStream(objFile);
MakeObjectFile mof = (MakeObjectFile) q.readObject();
System.out.println(mof.getStr());
} catch (Exception e) {
e.printStackTrace();
}
}
}