一、对象的序列化,就是将Object转换成byte序列,反之叫对象的反序列化
二、序列化流(ObjectOutStream)是过滤流——writeObject
反序列化流(ObjectInputStream)——readObject
三、序列化接口(Serializable)
对象必须实现序列化接口,才能进行序列化,否则将出现异常
这个接口,没有任何方法,只是一个标准。
四、下面一个例子使用对象流读写TV类创建的对象。(仔细观察例子中产生的television.txt文件中保存的对象序列化内容,尤其注意当TV类实现Serializable接口和不实现Serializable接口时,程序产生的television.txt文件在内容上的区别。)
程序运行结果:
changhong的名字:长虹电视
changhong的价格:5678
zinfei的名字:新飞电视
zeifei的价格:6666
package motong.com ;
import java.io .*;
public class Tv implements Serializable{//此时实现了序列化接口
String name;
int price;
public void setName(String s){
name = s;
}
public void setPrice(int n){
price = n;
}
public String getName(){
return name;
}
public int getPrice(){
return price;
}
}
package motong.com ;
import java.io .*;
public class Test {
public static void main(String[] args) {
Tv changhong = new Tv();
changhong.setName(“长虹电视”);
changhong.setPrice(5678);
File file = new File(“television.txt”);
try{
FileOutputStream fileOut = new FileOutputStream(file);
ObjectOutputStream objectOut = new ObjectOutputStream(fileOut);
objectOut.writeObject(changhong);
objectOut.close();
FileInputStream fileIn = new FileInputStream(file);
ObjectInputStream objectIn = new ObjectInputStream(fileIn);
Tv xinfei = (Tv)objectIn.readObject();
objectIn.close();
xinfei.setName(“新飞电视”);
xinfei.setPrice(6666);
System.out.println(“changhong的名字”+changhong.getName());
System.out.println(“changhong的价格”+changhong.getPrice());
System.out.println(“xinfei的名字”+xinfei.getName());
System.out.println(“xinfei的价格”+xinfei.getPrice());
}catch(ClassNotFoundException event){
System.out.println(“不能读出对象”);
}
catch(IOException event){
System.out.println(event);
}
}
}
当TV类实现Serializable接口时,程序产生的television.txt文件在内容为下图显示结果:
当TV类没有实现Serializable接口时,程序产生的television.txt文件在内容为下图显示结果:
总结:
一定要牢记:
对象的序列化,就是将Object转换成byte序列,反之叫对象的反序列化 此例子已经很好的作了说明