对象序列化
来源:互联网 发布:python insert(-1)函数 编辑:程序博客网 时间:2024/06/06 15:44
所谓对象序列化就是将对象的状态转换成字节流,以后可以通过这些值再生成相同状态的对象!
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对象,那么,会得到一个异常
:
举个例子:
class Student implements Serializable
{
public String name;
public int age;
public Student()
{
}
public Student(String name,int age)
{
this.name = name;
this.age = 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;
}
}
public class test
{
public static void main(String[] args)
{
// TODO 自动生成方法存根
Student stu1 = new Student("phinecos",20);
Student stu2 = null;
try
{
ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("c://a.data"));
out.writeObject(stu1);
out.flush();
out.close();
}
catch(Exception ex)
{
System.err.println(ex.getMessage().toString());
}
try
{
ObjectInputStream in = new ObjectInputStream( new FileInputStream("c://a.data"));
stu2 = (Student) in.readObject();
in.close();
}
catch (Exception e)
{
stu2 = new Student();
}
System.out.println( "Original data: " + stu2.getName()+" "+stu2.getAge() );
}
}
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对象,那么,会得到一个异常
:
举个例子:
class Student implements Serializable
{
public String name;
public int age;
public Student()
{
}
public Student(String name,int age)
{
this.name = name;
this.age = 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;
}
}
public class test
{
public static void main(String[] args)
{
// TODO 自动生成方法存根
Student stu1 = new Student("phinecos",20);
Student stu2 = null;
try
{
ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("c://a.data"));
out.writeObject(stu1);
out.flush();
out.close();
}
catch(Exception ex)
{
System.err.println(ex.getMessage().toString());
}
try
{
ObjectInputStream in = new ObjectInputStream( new FileInputStream("c://a.data"));
stu2 = (Student) in.readObject();
in.close();
}
catch (Exception e)
{
stu2 = new Student();
}
System.out.println( "Original data: " + stu2.getName()+" "+stu2.getAge() );
}
}
- Java对象序列化
- 对象序列化
- Java对象序列化
- 对象序列化笔记
- 对象的序列化
- 对象序列化
- 对象序列化
- Java对象序列化
- Java对象序列化
- java对象序列化
- Java 对象序列化
- 对象的序列化
- 序列化ArcEngine对象
- 对象序列化
- Java 对象序列化
- Java对象序列化
- 序列化对象传输
- 序列化对象
- 重写label控件,实现文本的每个字符的颜色随机
- css如何画表格斜线
- volatile用法
- DockPanel 子窗体如何在父窗体打开另一子窗体,以选项卡式存在
- python目录及文件操作
- 对象序列化
- 2008.12.27
- 2008.12.28
- 隔行扫描之锯齿消除(2)
- 大家好!
- vs2005 快捷代码
- ViewState使用兼谈序列化
- 【12月29日】
- 选择排序