1,当内存中的java对象的数据信息需要存到文件上时,需要将该对象进行序列化(serialize),反过来就是反序列化(disserialize)。序列化和反序列化反别由ObjectInputStream 和ObjectOutputStream负责。序列化就是将对象写入IO流中,反序列化相反。
2,参与序列化和反序列化的对象必须实现Serializable这个接口。实际上这个接口中什么都没有,只是起到标识的作用。java虚拟机识别后自动生成一个序列号。
3,如果不希望某个属性参与序列化,可以加上transient关键字
4,java中采用序列号对序列进行区分。比如两个人都写了Student类,但如果都implements了Serializable这个接口,那么java虚拟机就能区分它们。如果靠虚拟机自动生成序列号,可能以后修改了该类后序列号也会改变。建议手动写。
public static void main(String[] args) throws FileNotFoundException, IOException, ClassNotFoundException{
//序列化
ObjectOutputStream oos=new ObjectOutputStream (new FileOutputStream("student.txt"));
Student S=new Student(1,"zhang");
oos.writeObject(S);
//反序列化
ObjectInputStream ois=new ObjectInputStream(new FileInputStream("student.txt"));
S=(Student)ois.readObject();
System.out.println(S);
}
|