java对象的序列化和反序列化

本文实例为大家分享了java对象的序列化和反序列化,供大家参考,具体内容如下

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方法方法声明要与上面的保持完全一致),那么就允许我们以更加底层、更加继粒度的方式控制序列化和反序列化的过程。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...