处理流之一:对象流
ObjectInputStream和OjbectOutputSteam
用于存储和读取基本数据类型数据或对象的处理流。它的强大之处就是可以把Java中的对象写入到数据源中,也能把对象从数据源中还回来。
序列化:用ObjectOutputStream类 保存基本类型数据或对象的机制
反序列化: 用ObjectInputStream 类读取基木类型数据或对象的机制
ObjectOutputStream和ObjectlInputStream不能序 列化static利和transient修饰的成员变量
对象的序列化
1对象序列化机制允许把内存中的Java对象转换成平台无关的二二进制流,从而允许把这种二进制流持久地保存在磁盘上,或通过网络将这种二进制流传
输到另一个网络节点。当其它程序获取了这种二进制流,就可以恢复成原来的Java对象
2序列化的好处在于可将任何实现了Serializable接口的对象转化为字节数据,使其在保存和传输时可被还原
3序列化是RMI ( Remote Method Invoke -远程方法调用)过程的参数和返回值都必须实现的机制,而RMI是JavaEE的基础。因此序列化机制是JavaEE平台的基础
4如果需要让某个对象支持序列化机制,则必须让对象所属的类及其属性是可序列化的,为了让某个类是可序列化的,该类必须实现如下两个接口之一。否则,会抛出NotSerializableException异常
Serializable
Externalizable
下面就是针对 序列化和反序列化写的一段测试ObjectInputStream和OjbectOutputSteam的代码
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import org.junit.Test;
public class ObjectInputOutputTest {
@Test
public void Test1() {
//1创建流
ObjectOutputStream oos = null;
try {
oos = new ObjectOutputStream(new FileOutputStream("D:\\eclipse2\\eclipse\\IO流\\src\\Objcet.dat"));
//2
oos.writeObject(new String("我是LRQ"));
oos.flush();
oos.writeObject(new Person("LRQ", 22));
oos.flush();
} catch (IOException e) {
e.printStackTrace();
}finally {
if( oos != null) {
//3关闭流
try {
oos.close();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
}}
@Test
public void Test2() {
ObjectInputStream ois = null;
try {
ois = new ObjectInputStream(new FileInputStream("D:\\eclipse2\\eclipse\\IO流\\src\\Objcet.dat"));
Object obj = ois.readObject();
String str = (String) obj;
Person p = (Person) ois.readObject();
System.out.println(str);
System.out.println(p);
} catch (IOException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}finally {
if(ois != null) {
try {
ois.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}}
然后自定义一个Person类
import java.io.Serializable;
/*Person需要满足如下的要求,方可序列化
1.需要实现接口: Serializable
2.当前类提供-一个全局常量: serialVersionUID
3.除了当前Person类需要实现Serializable接口之外, 还必须保证其内部所有属性
也必须是可序列化的。(默认情况下, 基本数据类型可序列化)
*/
public class Person implements Serializable {
public static final long serialVersionUID = 34135351351L;
private String name;
private int age;
@Override
public String toString() {
return "Person [name=" + name + ", 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 Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public Person() {
super();
}
}