吧
/*
对象流的使用
* 1.ObjectInputStream 和 ObjectOutputStream
作用:
ObjectOutputStream:内存中的对象——>存储中的文件、通过网络传输出去
ObjectInputStream:存储中的文件、通过网络接收过来——>内存中的对象
- 2.作用:用于存储和读取基本数据类型数据或对象的处理流。它的强大之处就是可以把Java中的对象写入到数据源中,也能把对象从数据源中还原回来。
3.要想一个Java对象是可序列化的,需要满足相应的要求。见Person.class
4.序列化机制:
对象序列化机制允许把内存中的Java对象转换成平台无关的二进制流,从而允许吧这种
二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点,
反序列化:当其他程序获取了这种二进制流,就可以恢复成原来的Java对象。
package com.atguigu;
import org.junit.Test;
import java.io.*;
/**
* 对象流的使用
* 1.ObjectInputStream 和 ObjectOutputStream
* 2.作用:用于存储和读取基本数据类型数据或对象的处理流。它的强大之处就是可以把Java中的对象写入到
* 数据源中,也能把对象从数据源中还原回来。
*
* 3.要想一个Java对象是可序列化的,需要满足相应的要求。见Person.class
*
* 4.序列化机制:
* 对象序列化机制允许把内存中的Java对象转换成平台无关的二进制流,从而允许吧这种
* 二进制流持久地保存在磁盘上,或通过网络将这种二进制流传输到另一个网络节点,
* 当其他程序获取了这种二进制流,就可以恢复成原来的Java对象。
*
*
* @author Dxkstart
* @create 2021-06-03 15:05
*/
public class ObjectInput_OutputStream_Test {
/*
序列化的过程:将内存中的Java对象保存到磁盘中或通过网络传输出去
使用ObjectOutputStream实现
*/
@Test
public void testObject() {
ObjectOutputStream oos = null;
try {
//1.
oos = new ObjectOutputStream(new FileOutputStream(new File("C:\\Users\\Administrator\\Desktop\\IO\\Object.dat")));
//2.
oos.writeObject(new String("我爱中国"));
oos.flush();//刷新操作
oos.writeObject(new Person("泰勒斯威夫特", 22, new Account(9999)));
oos.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
//3.
try {
if (oos != null) {
oos.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
/*
反序列化:将磁盘中的对象还原为内存中的一个Java对象
使用ObjectInputStream来实现
*/
@Test
public void testObjectinputStream() {
ObjectInputStream ois = null;
try {
//1.
ois = new ObjectInputStream(new FileInputStream(new File("C:\\Users\\Administrator\\Desktop\\IO\\Object.dat")));
//2.
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 {
//3.
try {
if (ois != null) {
ois.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
- Person需要满足如下的要求,方可序列化
1.需要实现接口:Serializable
2.当前类提供一个全局常量:serialVersionUID
3.除了当前Person类需要实现Serializable接口外,还必须保证其内部所有属性
也必须是可序列化的。(默认情况下,基本数据类型是可序列化的)
补充:ObjectOutputStream 和 ObjectInoutStream不能序列化static 和 transient修饰的成员变量
*
package com.atguigu;
import java.io.Serializable;
/**
* Person需要满足如下的要求,方可序列化
* 1.需要实现接口:Serializable
* 2.当前类提供一个全局常量:serialVersionUID
* 3.除了当前Person类需要实现Serializable接口外,还必须保证其内部所有属性
* 也必须是可序列化的。(默认情况下,基本数据类型是可序列化的)
*
* 补充:ObjectOutputStream 和 ObjectInoutStream不能序列化static 和 transient修饰的成员变量
*
*
* @author Dxkstart
* @create 2021-06-03 15:27
*/
public class Person implements Serializable {
public static final long serialVersionUID = 47564312121L;//序列版本号
private String name;
private int age;
private Account acc;//账户
public Person() {
}
public Person(String name, int age, Account acc) {
this.name = name;
this.age = age;
this.acc = acc;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
", acc=" + acc +
'}';
}
}
class Account implements Serializable {
public static final long serialVersionUID = 47564312122L;//序列版本号
private double balance;
public Account() {
}
public Account(double balance) {
this.balance = balance;
}
public double getBalance() {
return balance;
}
public void setBalance(double balance) {
this.balance = balance;
}
@Override
public String toString() {
return "Account{" +
"balance=" + balance +
'}';
}
}