1. 什么是序列化
将对象转换为字节流保存起来,比如保存到文件里,并在以后还原这个对象,这种机制叫做对象序列化。(补充一句:把对象保存到永久存储设备上称为持久化)
2. 怎么实现序列化
需要实现serializable接口,java对象实现了这个接口就表明这个这个类的对象是可序列化的。
3. 序列化的注意事项
(1) 当一个对象序列化时,只能保存对象的非静态成员变量,不能保存方法和静态成员变量。
(2) 对象a引用了对象b,对象a序列化了,b也跟着序列化了。
(3) 如果一个可序化对象包含了一个不可序列化对象的引用,那么整个序列化操作就会失败,失败就会抛notserializableexception,所以,本身对象和引用对象都要实现serializable接口才可以进行序列化。
(4) transient的使用,成员变量或者引用标记为transient,那么对象仍可序死化,只是不会被序列化到文件中。
4. 代码
public class person implements serializable { private string name; private transient int age; public person(string name, int age) { super(); this.name = name; this.age = age; } public string tostring() { return this.name + "-" + this.age; } }
public class serializableclient { public static void main(string[] args) throws exception { person p1 = new person("zhangsan", 5); person p2 = new person("lisi", 100); //序列化 fileoutputstream fos = new fileoutputstream("person.txt"); objectoutputstream oos = new objectoutputstream(fos); oos.writeobject(p1); oos.writeobject(p2); system.out.println("---------"); //反序列化 fileinputstream fis = new fileinputstream("person.txt"); objectinputstream ois = new objectinputstream(fis); for(int i = 0; i < 2; i++) { person tempperson = (person)ois.readobject(); system.out.println(tempperson); } } }
输出结果:
---------
zhangsan-0
lisi-0
5. 更细粒度的控制序列化和反序化
当我们在序列化或者反序列化的类中实现了以上两个private方法(方法声明要与上面的保持完全一致),那么就允许我们以更加底层、更加继粒度的方式控制序列化和反序列化的过程。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支。
更多java对象的序列化和反序列化。
