您的位置:首页 > 编程语言 > Java开发

浅谈java中对象的序列化

2017-04-04 18:16 363 查看

一、定义及作用

我们所接触的大部分对象都是在程序开始运行时创建,并在程序终止后销毁。如果我们想将一个对象持久化的保存下来或者将它传送给别的用户,就需要用到对象的序列化。对象的序列化过程实际上是虚拟机将一个对象转换成一个字节序列,这个字节序列能够在存储在本地文件上也能够在网络上传输。同时,序列化的对象也能够进行反序列化,它能够根据对象生成的字节序列还原对象。

二、如何实现

能够被序列化的对象所属的类必须实现Serializable接口。Serializable接口是一个空接口,其中没有定义任何的方法,它相当于一个“标记”告诉编译器和虚拟机这个类的实例对象是可以被串行化。ObjectOutputStream类和ObjectInputStream类可以实现对象的写和读。它们能一次性的将一个对象写入对指定输出流并且能够从指定的输入流读出一个对象。Date类是可以被序列化的,因为它实现了Serializable接口。如下:
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.Date;

public class Main {

public static void main(String[] args) throws Exception {

ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("./src/test"));
oos.writeObject(new Date());

ObjectInputStream ois = new ObjectInputStream(new FileInputStream("./src/test"));
System.out.println((Date)ois.readObject());
}
}
需要注意的是,在实现Serializable接口的类中,静态变量和使用transient关键字的变量不会被串行化。如下:
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;

public class Main {

public static void main(String[] args) throws Exception {
Person p = new Person("张三",20,"中国");
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("./src/person.dat"));
oos.writeObject(p);
Person.name = "李四";
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("./src/person.dat"));
System.out.println((Person)ois.readObject());
}
}

class Person implements Serializable {
public static String name;
private transient int age;
private String address;

Person(String name, int age, String address) {
this.name = name;
this.age = age;
this.address = address;
}

@Override
public
4000
String toString() {
return "Person [name=" + name + ", age=" + age + ", address=" + address
+ "]";
}

}
程序运行结果如下:



程序的结果很好的验证了我们的结论。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: