为什么要进行序列化和反序列化?
当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。那么当两个Java进程进行通信时,能否实现进程间的对象传送呢?答案是可以的。如何做到呢?这就需要Java序列化与反序列化了。换句话说,一方面,发送方需要把这个Java对象转换为字节序列,然后在网络上传送;另一方面,接收方需要从字节序列中恢复出Java对象。当我们明晰了为什么需要Java序列化和反序列化后,我们很自然地会想Java序列化的好处。其好处一是实现了数据的持久化,通过序列化可以把数据永久地保存到硬盘上(通常存放在文件里),二是,利用序列化实现远程通信,即在网络上传送对象的字节序列。
对象的序列化(Serialize)
将java对象写入IO流,转化为字节流
对象的反序列化(Deserialize)
从字节流中恢复Java对象
基本使用
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
public class IOobject {
public static void main(String[] args) {
outputobject("object.txt");
inputobject("object.txt");
}
//序列化,将对象写入IO流中
public static void outputobject(String f) {
FileOutputStream file;
try {
file = new FileOutputStream(f);
ObjectOutputStream oo=new ObjectOutputStream(file);
Person person =new Person("小王", 12);
oo.writeObject(person);
//每次避免抛出异常,只需要设置Exception就好。这是所有异常类的基类
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
//反序列化,将从IO流中读取Java对象
public static void inputobject(String ff) {
try {
ObjectInputStream in=new ObjectInputStream(new FileInputStream(ff));
Person p=(Person)in.readObject();
System.out.println("名字为"+p.getName()+",年龄为"+p.getAge());
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
class Person implements java.io.Serializable{
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
private int age;
public Person(String name,int age) {
System.out.println("这是个有参数的构造器");
this.name=name;
this.age=age;
}
}