`

认识一下Java序列化

    博客分类:
  • java
阅读更多

说明:本文只是简单介绍Java的序列化,大牛们可以绕道而行~

概述:

  1. 序列化是什么?
    就是将一个Java对象“流”化(转换成二进制数据流),流化后就能将对象保存到某种介质(磁盘、数据库等)或在某种介质(网络)上传送。
    简单的说就是  对象 --> 二进制数据,计算机就是处理二进制数据的专家,所以无论你存储,传输还是做某些操作(例如:加密、转换)都是可行的。
  2. 序列化和反序列化
    序列化:对象 --> 二进制数据流
    反序列化:二进制数据流 --> 对象
    这个过程让我想到的超时空传送:从一个地方把你打成分子并记录结构,然后通过某种高科技的东西进行传送,然后在目的地把你再按照记录组装出来。
  3. 实现序列化的方式
    1.打上标记接口Serializable
    2.实现Externalizable接口并实现里面的相关方法
  4. 两种方式的比较
    1.上手度:Serializable比较容易,直接继承接口即可。
    2.性能上:Externalizable要略好于Serializable。
    3.选择:往往我们选择Serializable,因为他简单。
  5. 我们看个例子,感官认识一下 请看演示一
    1.我们定义一个Book类,让其打上标记接口Serializable,OK我们的序列化已经完成一多半了。
    2.序列化:我们用ObjectOutputStream去写一个Book对象到我们的介质中(这里是一个data文件)
    3.反序列化:我们用ObjectInputStream去将介质中的流读出来并转换成Book的对象。
    4.这里注意 当反序列化的时候 必须提供对应类的class文件,他就像设计图 告知程序将流转成什么样子的对象。
    5.序列化就是这么简单~
  6. 其实不然,序列化不仅仅只有这么简单
    1.序列化的对象中还有其他对象!那序列化的时候必须需要这个其他对象也能序列化。见 Author定义
    2.Java序列化机制只会序列化一次相同的Java对象。见 演示二
    3.被static和transient修饰的field,不进行序列化。没有演示...
       1.static代表的是类状态。
       2.transient是瞬态(可以理解为临时数据)。
    4.自定义序列化:自己实现一个类似编码器和解码器的东西。 没有演示...
    5.Externalizable:需要自己实现序列化和反序列化的 序列化方式 没有演示...
    6.序列化版本:见Book类的serialVersionUID
       1.为了保证类变化后的兼容性
       2.保证移植性
  7. 本文只是简单的介绍了序列化 并列举了一些的关注点,有兴趣的朋友可以深入研究。

package com.cxyapi.io;

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

/** 认识一下Java序列化
 * @author cxy @ www.cxyapi.com
 */
public class SerializableTest
{
	public static void main(String[] args) throws Exception
	{
		//演示一:最简单的序列化例子
		ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream("d:/cxyapi.data"));
		Book b1=new Book("Java教程");
		oos.writeObject(b1);
		oos.close();
		
		ObjectInputStream ois=new ObjectInputStream(new FileInputStream("d:/cxyapi.data"));
		Book b2=(Book)ois.readObject();
		System.out.println(b2.getName());
		ois.close();
		System.out.println("=====================");
		
		//演示二:一个包含其他对象的对象
		oos=new ObjectOutputStream(new FileOutputStream("d:/cxyapi.data"));
		Author a=new Author("cxy");
		//点1:两本书我存同一个对象(作者)
		BookExt be=new BookExt("cxyapi", a);
		BookExt be1=new BookExt("snkcxy.iteye.com", a);
		oos.writeObject(be);
		//点2:我存2遍be1
		oos.writeObject(be1);
		oos.writeObject(be1);
		oos.close();
		
		ois=new ObjectInputStream(new FileInputStream("d:/cxyapi.data"));
		//存3个对象 我取3个对象,多取会报错
		BookExt bec=(BookExt)ois.readObject();
		BookExt be1c=(BookExt)ois.readObject();
		BookExt be1cc=(BookExt)ois.readObject();
		System.out.println(bec.getName());
		System.out.println(be1c.getName());
		System.out.println(be1cc.getName());
		//判断最后2个对象 其实是一个对象,这是Java序列化机制所知,它不会一下序列化出很多同样的对象
		System.out.println(be1c==be1cc);
		System.out.println(be1c.hashCode());
		System.out.println(be1cc.hashCode());
		//判断作者,其实也是同一个对象
		System.out.println(bec.getAuthor()==be1c.getAuthor());
		System.out.println(bec.getAuthor().hashCode());
		System.out.println(be1c.getAuthor().hashCode());
		ois.close();
		System.out.println("=====================");
	}
}

class Book implements  Serializable
{
	private static final long serialVersionUID = -564380176443249810L;
	private String name;
	
	public Book(String name)
	{
		this.name=name;
	}

	public String getName()
	{
		return name;
	}

	public void setName(String name)
	{
		this.name = name;
	}
}


/** 扩展书类,实现序列化 并且里面加入了作者信息
 * @author cxy @ www.cxyapi.com
 * 2013-3-12 下午11:18:22
 */
class BookExt implements  Serializable
{
	
	private String name;
	
	private Author author;
	
	public BookExt(String name,Author author)
	{
		this.name=name;
		this.author=author;
	}

	public String getName()
	{
		return name;
	}

	public void setName(String name)
	{
		this.name = name;
	}

	public Author getAuthor()
	{
		return author;
	}

	public void setAuthor(Author author)
	{
		this.author = author;
	}
}

/** 必须能序列化 不然 BookExt也将不能序列化
 * @author cxy @ www.cxyapi.com
 * 2013-3-12 下午11:42:40
 */
class Author implements  Serializable
{
	private String name;
	
	public Author(String name)
	{
		this.name=name;
	}

	public String getName()
	{
		return name;
	}

	public void setName(String name)
	{
		this.name = name;
	}
}

 

声明:

1.原创文章,转载请标明并加本文连接。

2.文章反映个人愚见,如有异议欢迎讨论指正

3.更多的内容请看我的  个人博客(测试版)

5
2
分享到:
评论
2 楼 yannis_123 2013-07-09  
    
1 楼 javaseer 2013-03-13  
还能看懂

相关推荐

    java 序列化的问题 如何认识和解决序列化 demo

    java 序列化的问题 如何认识和解决序列化 java serializable

    Java_序列化的高级认识

    Java_序列化的高级认识,很经典的资料,大家做参考

    Java 序列化的高级认识1

    Transient 关键字的作用是控制变量的序列化,在变量声明前加上该关键字,可以阻止该变量被序列化到文件中,在被反序列化后,transient 变量的值被设为

    2022年J2SE中的序列化的认识Java教程.docx

    2022年J2SE中的序列化的认识Java教程.docx

    J2SE中的序列化的认识

    java中处处体现着简单的程序设计风格,序列化作为最常用的功能之一,在java中的设计尤为“简单”。在ObjectInputStream 和ObjectOutputStream的帮助下,我们可以轻松的实现序列化。 只要我们的class 实现了java.io....

    Java开发详解.zip

    031217_【第12章:JAVA IO】_对象序列化笔记.pdf 031218_〖第12章:JAVA IO〗_实例操作—单人信息管理程序笔记.pdf 031219_〖第12章:JAVA IO〗_实例操作:投票程序笔记.pdf 031301_【第13章:Java类集】_认识类集、...

    Java思维导图xmind文件+导出图片

    理解通信协议传输过程中的序列化和反序列化机制 基于框架的RPC通信技术 WebService/ApacheCXF RMI/Spring RMI Hession 传统RPC技术在大型分布式架构下面临的问题 分布式架构下的RPC解决方案 Zookeeper ...

    java基础案例与开发详解案例源码全

    1.2 认识Java语言3 1.2.1 Java语言特性3 1.2.2 JavaApplet4 1.2.3 丰富的类库4 1.2.4 Java的竞争对手5 1.2.5 Java在应用领域的优势7 1.3 Java平台的体系结构7 1.3.1 JavaSE标准版8 1.3.2 JavaEE企业版10 1.3.3 Java...

    java面试题

    答:JDO是java对象持久化的新的规范,为java data object的简称,也是一个用于存取某种数据仓库中的对象的标准化API。 CORBA? 答:CORBA标准是公共对象请求代理结构,用途为:用不同的程序设计语言书写,在不同的...

    八字排盘java源码-clj-uuid:Clojure的RFC4122唯一标识符(v1、v3、v4、v5、squid)

    的序列化和操作。 RFC4122 UUID 提供的值的本质性质是巨大的命名空间和确定性数学模型,通过它可以导航它。 UUID 代表了一种极其强大和通用的计算技术,但它经常被忽视和利用不足。 在我看来,这部分是由于可用库的...

    jpeg压缩的matlab代码-dct-extraction:用于直接从JPEG压缩文件中提取DCT系数的C代码。旨在与Java结合

    AC库(libExportDCT),它访问libjpeg并以序列化(且非常简单)的形式获取感兴趣的数据,然后Java可以使用JNA对其进行读取。 它要求libjpeg在系统中已经可用。 我建议使用版本8d,而不是版本9。 一个访问...

    javascript学习之json入门

    它是一种轻量级的数据交换格式,是基于Javascript的一个子集,可以叫做Javascript对象表示法,是存储和交换文本信息的语法,但它并不是Javascript独有的数据格式,其它很多语言都可以对JSON进行解析和序列化。...

    Flex企业应用开发实战源代码

    5.2.4 BlazeDS的序列化机制 156 5.2.5 FlexClient和FlexSession 161 5.3 BlazeDS的配置 162 5.3.1 配置MessageBrokerServlet 162 5.3.2 services-config.xml 163 5.3.3 Channel和Endpoint 165 5.3.4 Service、...

    Python语言程序设计源代码.zip

    与其他高级编程语言如C、C++和Java等相比,Python在数据的表示、处理和可视化方面都有绝对的优势。有编程基础的学习者在学习Python时最好能忘掉以往程序设计语言的语法,彻底转变观念,以全新的姿态融入到Python的...

    c#学习笔记.txt

    很多人觉得它应该像C或者C++,但事实上它更像是java的一个clone,所以作为入门,读一下清华大学出版社出版的《Java 语言与面向对象程序设计》可能会对你有所帮助。本文假定你具备一切学习此语言所需的知识,没有也不...

    Python语言程序设计PPT课件.zip

    与其他高级编程语言如C、C++和Java等相比,Python在数据的表示、处理和可视化方面都有绝对的优势。有编程基础的学习者在学习Python时最好能忘掉以往程序设计语言的语法,彻底转变观念,以全新的姿态融入到Python的...

    Python语言程序设计习题答案.zip

    与其他高级编程语言如C、C++和Java等相比,Python在数据的表示、处理和可视化方面都有绝对的优势。有编程基础的学习者在学习Python时最好能忘掉以往程序设计语言的语法,彻底转变观念,以全新的姿态融入到Python的...

    asp.net知识库

    泛型的序列化问题 .NET 2.0 泛型在实际开发中的一次小应用 C#2.0 Singleton 的实现 .Net Framwork 强类型设计实践 通过反射调用類的方法,屬性,字段,索引器(2種方法) ASP.NET: State Server Gems 完整的动态加载/卸载...

    并行计算课程设计(报告+代码+可执行文件)

    这次的大作业虽然是对以前实验的整合,但它加深了我对并行计算的印象,也使我对并行计算知识的理解更加深刻,也使我认识到了自己很多不足之处。学习并行计算的历程不会因为完成本次大作业而停止,我们是为了用知识...

Global site tag (gtag.js) - Google Analytics