用于存储和读取基本数据类型数据或对象的处理流,能够把Java中的对象写入到数据源中,也能把对象从数据源中还原回来java
注意:ObjectOutputStream和ObjectInputStream不能序列化static和transient修饰的成员变量网络
对象序列化机制容许把内存中的Java对象转换成平台无关的二进制流,从而容许把这种二进制流持久地保存在磁盘上,或经过网络将这种二进制流传输到另外一个网络节点。当其它程序获取了这种二进制流,就能够恢复成原来的Java对象ui
若是须要让某个对象支持序列化机制,该类必须实现以下两个接口之一,不然,会抛出NotSerializableException异常this
须要当前类提供一个全局常量serialVersionUID版本控制
public static final long serialVersionUID = 4892322646L;code
其中数值没有严格要求,随便写一个便可对象
内部全部属性也必须是可序列化的(默认状况下,基本数据类型和String是可序列化的)blog
若是某个类的属性不是基本数据类型或 String 类型,而是另外一个引用类型,那么这个引用类型必须是可序列化的(实现Serializable接口),不然拥有该类型的Field 的类不能序列化接口
使用ObjectOutputStream来实现内存
public void test1(){ //序列化过程:将内存中的java对象保存在磁盘中或经过网络传输出去 ObjectOutputStream oos = null; try { oos = new ObjectOutputStream(new FileOutputStream("object.dat")); oos.writeObject(new String("我爱北京天安门")); oos.flush(); } catch (IOException e) { e.printStackTrace(); } finally { try { if(oos != null) oos.close(); } catch (IOException e) { e.printStackTrace(); } } }
使用ObjectInputStream来实现
public void test2(){ //反序列化过程:将磁盘文件中对象还原为内存中的一个java对象 ObjectInputStream ois = null; try { ois = new ObjectInputStream(new FileInputStream("object.dat")); Object object = ois.readObject(); String s = (String) object; System.out.println(s); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } finally { try { if(ois != null) ois.close(); } catch (IOException e) { e.printStackTrace(); } } }
注意自定义类必定要实现Serializable接口和有一个全局变量serialVersionUID
public class Person implements Serializable { public static final long serialVersionUID = 4892322646L; private String name; private int age; public Person() { } public Person(String name, int age) { this.name = name; this.age = age; } 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; }
public void test1(){ //序列化过程:将内存中的java对象保存在磁盘中或经过网络传输出去 ObjectOutputStream oos = null; try { oos = new ObjectOutputStream(new FileOutputStream("object.dat")); oos.writeObject(new String("我爱北京天安门")); oos.flush(); oos.writeObject(new Person("殷志源",42)); oos.flush(); } catch (IOException e) { e.printStackTrace(); } finally { try { if(oos != null) oos.close(); } catch (IOException e) { e.printStackTrace(); } } }
public void test2(){ //反序列化过程:将磁盘文件中对象还原为内存中的一个java对象 ObjectInputStream ois = null; try { ois = new ObjectInputStream(new FileInputStream("object.dat")); Object object = ois.readObject(); String s = (String) object; Person p = (Person) ois.readObject(); System.out.println(s); System.out.println(p); } catch (IOException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } finally { try { if(ois != null) ois.close(); } catch (IOException e) { e.printStackTrace(); } } }
至关于一个标识
目的是以序列化对象进行版本控制,有关各版本反序列化时是否兼容
若是对类进行了修改,可是定义了serialVersionUID,反序列化的时候依旧能够识别出其内容
若是类没有显示定义这个静态常量,它的值是Java运行时环境根据类的内部细节自动生成的。若类的实例变量作了修改,serialVersionUID可能发生变化。因此须要显示声明