一、对象流分为:
ObjectinputStream和ObjectoutputStream
1、用于存储和读取基本数据类型数据或对象的处理流。它的强大之处就是可以把Java 数据源中的对象写入到数据源中,也能把对象从数据源中恢复回来。
2、序列化和反序列化
序列化:用ObjectoutputStream 类保存基本类型数据或对象的机制。
反序列化:用ObjectinputStream类读取基本类型数据或对象的机制。
3、ObjectinputStream和ObjectoutputStream 不能序列化static和transient修饰的成员变量。
二、对象的序列化机制:
1、对象的序列化机制允许把内存中的Java 对象转换成平台无关的二进制流,从而允许把这种二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点。当其它程序获取了这种二进制流,就可以恢复成原来的Java 对象。
2、序列化的好处在于可将任何实现了Serializable接口的对象转化为字节数据,使其在保存和传输对象时可被还原。
3、序列化是RMI(Remote Method Inkove -远程方法调用)过程的参数和返回值都必须实现的机制,而RMI是JavaEE的基础。因此序列化机制是JavaEE的基础。
4、如果需要让某个对象支持序列化机制,则必须让对象的类及其属性是可序列化的为了让某个类是可序列化的,则该类必须实现如何两个接口之一。
否则,会抛出初始化异常:
Serializable
Externalizable
三、案例实战
package Com.bigDataWork_IO;
// 对象流的使用
import org.junit.Test;
import java.io.FileInputStream;
import java.io.FileOutputStream;
//import java.io.IOException;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
// 对象序列化机制
public class ObjectOutputStreamTest {
@Test
public void TestObjectOutputStream() {
ObjectOutputStream oos=null;
try {
oos = new ObjectOutputStream(new FileOutputStream(“object.txt”));
oos.writeObject(new String(“我爱山西太原”));
oos.flush();
}catch (IOException e){
e.printStackTrace();
}finally {
if (oos !=null){
try {
oos.close();
}catch (Exception e){
e.printStackTrace();
}
}
}
}
/**对象的反序列化机制
将磁盘文件中的对象还原为内存中的一个java对象
使用:ObjectInputStream()
*/
@Test
public void testObjectInputStream(){
ObjectInputStream ois =null;
try {
ois = new ObjectInputStream(new FileInputStream(“object.txt”));
Object obj = ois.readObject();
String str =(String)obj;
System.out.println(str);
}catch (ClassNotFoundException | IOException e){
e.printStackTrace();
}finally {
if (ois !=null){
try{
ois.close();
}catch (IOException e){
e.printStackTrace();
}
}
}
}
}
反序列化的输出结果:
【转载注明出处,还望尊重原创 】
【作者水平有限,如有错误欢迎指正 .】
本文地址:https://blog.csdn.net/weixin_46163590/article/details/109258868
如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!