码迷,mamicode.com
首页 > 编程语言 > 详细

Java中的Serializable接口transient关键字,及对象IO

时间:2016-08-17 12:15:00      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:

1、什么是序列化和反序列化
Serialization是一种将对象转为为字节流的过程;deserialization是将字节流恢复为对象的过程。

2、什么情况下需要序列化
a)当你想把的内存中的对象保存到一个文件中或者数据库中时候;
b)当你想用套接字在网络上传送对象的时候;
c)当你想通过RMI传输对象的时候;

3、如何实现序列化
将需要序列化的类实现Serializable接口就可以了,Serializable接口和Cloneable接口一样,不含任何方法,是个标记接口。

4、代码分析

package com.tonyluis;

import java.io.*;

public class Solution {
	public static void main(String args[]) {
		ObjectOutputStream objectos = null;
		SerializableTest myTest = new SerializableTest("str", 12, 1, "123456", 8);
		try {
			objectos = new ObjectOutputStream(new FileOutputStream("test.dat"));
			objectos.writeObject(myTest);
			objectos.flush();
			objectos.close();
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

		ObjectInputStream objectin;
		SerializableTest mts = null;
		try {
			objectin = new ObjectInputStream(new FileInputStream("test.dat"));
			mts = (SerializableTest) objectin.readObject();
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (ClassNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

		System.out.println(mts);
		// 注意,没有覆盖equals()方法,Object类的equals()默认是地址的比较
		System.out.println(mts.equals(myTest));
	}
}

class SerializableTest implements Serializable {
	// 序列化 ID 在 Eclipse 下提供了两种生成策略
	// 一个是固定的 1L,一个是随机生成一个不重复的 long 类型数据(实际上是使用 JDK 工具生成)
	// 如果没有特殊需求,就是用默认的 1L 就可以
	static final long serialVersionUID = 1L;
	String name;
	int num;
	static int staticNum;
	//transient关键字是不能序列化的
	transient String pwd;
	transient int num0;

	SerializableTest(String name, int num, int staticNum, String pwd, int num0) {
		this.name = name;
		this.num = num;
		this.staticNum = staticNum;
		this.pwd = pwd;
		this.num0 = num0;
	}

	public String toString() {
		return "name=" + name + ",num=" + num + ",staticNum=" + staticNum + ",pwd=" + pwd + ",num0=" + num0;
	}
}

 

 输出结果:

name=str,num=12,staticNum=1,pwd=null,num0=0
false

5.序列化前和序列化后的对象的关系


反序列化还原后的对象地址与原来的的地址不同,序列化前后对象的地址不同了,但是内容是一样的,而且对象中包含的引用也相同。换句话说,通过序列化操作,我们可以实现对任何可Serializable对象的”深度复制(deep copy)"——这意味着我们复制的是整个对象网,而不仅仅是基本对象及其引用。对于同一流的对象,他们的地址是相同,说明他们是同一个对象,但是与其他流的对象地址却不相同。也就说,只要将对象序列化到单一流中,就可以恢复出与我们写出时一样的对象网,而且只要在同一流中,对象都是同一个。

 

Java中的Serializable接口transient关键字,及对象IO

标签:

原文地址:http://www.cnblogs.com/tonyluis/p/5779187.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!