Java 对象序列化与反序列化

对象序列化

对象序列化

对象序列化定义

所谓的对象序列化就是将 保存在内存中的对象数据转换为二进制数据流进行传输的操作 ;但不是所有对象都可以进行序列化,要被序列化的的对象那么其所在的类一定要实现 java.io.Serializable 接口,该接口并没有认识的操作方法,因为该接口是一个 标识接口

可以被序列化的类

import java.io.Serializable;

@SuppressWarnings("serial")
class Book implements Serializable { 
	private String title ; 
	private double price ;
	public Book(String title , double price) {
		this.price = price ;
		this.title = title ; 
	}
	public String toString() {
		return "this.title + "\t" + this.price";
	}
}

如上,就实现了一个可以被序列化的类,(使用了压制警告)。

如此,Book类就可以实现二进制的传输了!

实现序列化和反序列化

序列化类:

  • java.io.ObjectOutputStream
    • 将对象转为指定格式的二进制数据
  • 构造方法:
public ObjectOutputStream(OutputStream out)
  • 输出对象:
public final void writeObject(Object obj)

反序列化类:

  • java.io.ObjectInputStream
    • 将已经序列化的对象转换回原本的对象内容
  • 构造方法:
public ObjectInputStream(InputStream in)
  • 读取对象:
public final Object readObject()

实现序列化对象操作

@SuppressWarnings("serial")
class Book implements Serializable { 
	private String title ; 
	private double price ;
	public Book(String title , double price) {
		this.price = price ;
		this.title = title ; 
	}
	public String toString() {
		return this.title + "\t" + this.price ;
	}
}
public class TestDemo { 
	public static void main(String [] args) throws Exception {
		ser();
	}
	public static void ser() throws Exception {
		ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(new File("F:" + File.separator + "demo" + File.separator + "Byte.txt")));
		oos.writeObject(new Book("Java开发",110.1));
		oos.close();
	}
} 

实现反序列化类

	public static void dser() throws Exception {
		ObjectInputStream ois = new ObjectInputStream(new FileInputStream (new File("F:" + File.separator + "demo" + File.separator + "Byte.txt")));
		Object obj = ois.readObject();// 按照Object读取
		Book book = (Book) obj;// 向下转型
		System.out.println(book);
		ois.close();
	}

序列化与反序列化完整实现

package helloworld;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;

@SuppressWarnings("serial")
class Book implements Serializable { 
	private String title ; 
	private double price ;
	public Book(String title , double price) {
		this.price = price ;
		this.title = title ; 
	}
	public String toString() {
		return this.title + "\t" + this.price ;
	}
}
public class TestDemo { 
	public static void main(String [] args) throws Exception {
		ser();  // 实现序列化
		dser(); // 实现反序列化
	}
	public static void ser() throws Exception {
		ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(new File("F:" + File.separator + "demo" + File.separator + "Byte.txt")));
		oos.writeObject(new Book("Java开发",110.1));// 输出
		oos.close();
	}
	public static void dser() throws Exception {
		ObjectInputStream ois = new ObjectInputStream(new FileInputStream (new File("F:" + File.separator + "demo" + File.separator + "Byte.txt")));
		Object obj = ois.readObject();// 按照Object读取
		Book book = (Book) obj;// 向下转型
		System.out.println(book);
		ois.close();
	}
} 

transient 关键字

通过序列化和反序列化的code实现,我们发现:序列化操作时是将整个对象的所有属性内容进行保存;但是如果某些属性的内容不需要被保存就可以通过 transient 关键字定义。

private transient String title;

由定义可知,title属性不可以被序列化操作。

总结

不是所有的类都需要被序列化,只有需要传输的对象所在的类才需要序列化对象。

posted @ 2019-07-14 20:33  Mirror王宇阳  阅读(344)  评论(0编辑  收藏  举报