Java对象流
ObjectInputStream和OjbectOutputSteam
用于存储和读取对象的处理流。它的强大之处就是可以把Java中的对象写入到数据源中,也能把对象从数据源中还原回来。
序列化(Serialize):用ObjectOutputStream类将一个Java对象写入IO流中
反序列化(Deserialize):用ObjectInputStream类从IO流中恢复该Java对象
涉及下Java对象序列化机制:
对象序列化机制允许把内存中的Java对象转换成平台无关的二进制流,从而允许把这种二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点。当其它程序获取了这种二进制流,就可以恢复成原来的Java对象。
序列化的好处在于可将任何实现了Serializable接口的对象转化为字节数据,使其在保存和传输时可被还原。
序列化是 RMI(Remote Method Invoke – 远程方法调用)过程的参数和返回值都必须实现的机制,而 RMI 是 JavaEE 的基础。因此序列化机制是 JavaEE 平台的基础
如果需要让某个对象支持序列化机制,则必须让其类是可序列化的,为了让某个类是可序列化的,该类必须实现如下两个接口之一:
Serializable
Externalizable(Serializable的子类)
要实现序列化类的条件:1、要求此类是可序列化的:实现Serializable接口即可
2、要求此类中的属性同样是实现了Serializable接口的 注意:这两个条件任意没有实现的话,都会报java.io.NotSerializableException异常
3、提供一个版本号:private statis final long serialVersionUID
在这解析下使用这个版本号:
serialVersionUID用来表明类的不同版本间的兼容性
如果类没有显示定义这个静态变量,它的值是Java运行时环境根据类的内部细节自动生成的。
若类的源代码作了修改,serialVersionUID 可能发生变化。故建议,显示声明。
希望类的不同版本对序列化兼容,不希望类的不同版本对序列化兼容,因此需确保类的不同版本具有相同的serialVersionUID
不希望类的不同版本对序列化兼容,因此需确保类的不同版本具有不同的serialVersionUID
4、使用static或transient修饰的属性,不可实现序列化
Demo如下:
/**
*
* @author KingDom
* java对象流的使用:ObjectInputStream、ObjectOutputStream
*
*/
public class TestObjectIOStream {
//对象的序列号过程,将内存中的对象通过ObjectOutputStream转换成二进制流,存储在硬盘文件中
@Test
public void testObjectOutputStream(){
ObjectOutputStream oos = null;
try {
oos = new ObjectOutputStream(new FileOutputStream(new File("oos.txt")));
Person person1 = new Person("KD", 21);
Person person2 = new Person("KB", 31);
oos.writeObject(person1);
oos.flush();
oos.writeObject(person2);
oos.flush();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
if(oos != null){
try {
oos.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
//对象的反序列化过程:将硬盘中的文件通过ObjectInputStream转换成相应的对象
@Test
public void testObjectInputStream(){
ObjectInputStream ois = null;
try {
ois = new ObjectInputStream(new FileInputStream(new File("oos.txt")));
Person person1 = (Person)ois.readObject();
System.out.println(person1);
Person person2 = (Person)ois.readObject();
System.out.println(person2);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
ois.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
/*
* 要实现序列化的类条件: 1、要求此类是可序列化的:实现Serializable接口
* 2、要求类的属性同样的要实现Serializable接口 否则会报错:java.io.NotSerializableException
* 3、提供一个版本号:private statis final long serialVersionUID
* 4、使用static或transient修饰的属性,不可实现序列化
*/
class Person implements Serializable{
private static final long serialVersionUID = 1L;
private String name;
private Integer age;
public Person(String name, Integer age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Person [name=" + name + ", age=" + age + "]";
}
}