`
chenshuyi
  • 浏览: 29381 次
文章分类
社区版块
存档分类
最新评论

Java序列化与Java串行化

 
阅读更多

  今年大四了,拼命做笔试题,看到了Java序列化是什么?

  其实Java序列化和Java串行化都是一样的,都对应英文中的Serializable。可能是翻译的时候不统一,我一开始的时候以为是两个不同的概念呢。

  一、什么是序列化?

  一个对象随着创建而存在,随着程序结束而结束。那如果我要保存一个对象的状态呢?Java序列化能够将对象的状态写入byte流存储起来,也从其他地方将byte流读取出来,重新构造一个新的对象。这种机制允许你将对象通过网络进行传播,并且可以随时把对象持久化到数据库、文件系统中。简而言之,序列化就是将一个对象的状态保存起来,而反序列化就是将已经保存的流对象恢复成原来的对象。

  二、如何实现序列化?

  实现序列化有一个条件,即实现序列化的类必须实现java.io.Serializable接口。之后可以利用ObjectInputStream的readOjbect()方法和OjbectOutputStream的writeObject()方法进行对象的读和写,即反序列化和序列化。具体的demo如下:


a)Java对象

在java中要想使一个java对象可以实现序列化与反序列化,必须让该类实现java.io.Serializable接口

java.io.Serializable接口定义如下:

publicinterfaceSerializable {

}

从上述定义中可以看到该接口中未定义任何方法,这大大的简化了开发者

b)序列化主要依赖java.io.ObjectOutputStream类,该类对java.io.FileOutputStream进一步做了封装,这里主要使用ObjectOutputStream类的writeObject()方法实现序列化功能

Demo:

/**

*将对象序列化到磁盘文件中

*@paramo

*@throwsException

*/

publicstaticvoidwriteObject(Object o)throwsException{

File f=newFile("d:""user.tmp");

if(f.exists()){

f.delete();

}

FileOutputStream os=newFileOutputStream(f);

//ObjectOutputStream核心类

ObjectOutputStream oos=newObjectOutputStream(os);

oos.writeObject(o);

oos.close();

os.close();

}

c)反序列化主要依赖java.io.ObjectInputStream类,该类对java.io.InputStream进一步做了封装,这里主要使用ObjectInputStream类的readObject()方法实现序列化功能

Demo:

/**

*反序列化,将磁盘文件转化为对象

*@paramf

*@return

*@throwsException

*/

publicstaticUser readObject(File f)throwsException{

InputStream is=newFileInputStream(f);

//ObjectOutputStream核心类

ObjectInputStream ois=newObjectInputStream(is);

return(User)ois.readObject();

}

贴出完整的demo

Java对象:

packagecom.io.bean;

importjava.io.Serializable;

publicclassUserimplementsSerializable{

privateintuserId;

privateStringuserName;

privateStringuserSex;

privateintuserAge;

publicintgetUserAge() {

returnuserAge;

}

publicvoidsetUserAge(intuserAge) {

this.userAge= userAge;

}

publicintgetUserId() {

returnuserId;

}

publicvoidsetUserId(intuserId) {

this.userId= userId;

}

publicString getUserName() {

returnuserName;

}

publicvoidsetUserName(String userName) {

this.userName= userName;

}

publicString getUserSex() {

returnuserSex;

}

publicvoidsetUserSex(String userSex) {

this.userSex= userSex;

}

@Override

publicString toString() {

returnthis.getUserId() +" "+this.getUserName() +" "

+this.getUserSex() +" "+this.getUserAge();

}

}

序列化与反序列化

packagecom.io.test;

importjava.io.File;

importjava.io.FileInputStream;

importjava.io.FileOutputStream;

importjava.io.InputStream;

importjava.io.ObjectInputStream;

importjava.io.ObjectOutputStream;

importcom.io.bean.User;

publicclassTestSerializable {

/**

*将对象序列化到磁盘文件中

*@paramo

*@throwsException

*/

publicstaticvoidwriteObject(Object o)throwsException{

File f=newFile("d:""user.tmp");

if(f.exists()){

f.delete();

}

FileOutputStream os=newFileOutputStream(f);

//ObjectOutputStream核心类

ObjectOutputStream oos=newObjectOutputStream(os);

oos.writeObject(o);

oos.close();

os.close();

}

/**

*反序列化,将磁盘文件转化为对象

*@paramf

*@return

*@throwsException

*/

publicstaticUser readObject(File f)throwsException{

InputStream is=newFileInputStream(f);

//ObjectOutputStream核心类

ObjectInputStream ois=newObjectInputStream(is);

return(User)ois.readObject();

}

publicstaticvoidmain(String[] args)throwsException{

/*****************将对象序列化***************/

/*

User user=new User();

user.setUserId(1);

user.setUserName("张艺谋");

user.setUserSex("");

user.setUserAge(50);

TestSerializable.writeObject(user);

*/

/*****************将对象序反列化***************/

User user=TestSerializable.readObject(newFile("d:""user.tmp"));

System.out.println(user);

}

}


参考资料:

1.http://www.blogjava.net/sxyx2008/archive/2009/11/09/301663.html

2.http://blog.csdn.net/yakihappy/article/details/3979373

分享到:
评论

相关推荐

    Java 串行化(序列化)Serializable/Externalizable

    在实际项目中,例如在网络通信中传递复杂对象,或者是将对象持久化到数据库或文件,Java序列化都是一种常用的工具。在 serializable-prj 项目中,可能包含了各种示例代码,展示了如何在Java中实现和使用序列化功能。...

    java串行化详细的介绍了java串行化的概念

    ### Java序列化详解 在Java开发中,序列化是一个非常重要的概念,它涉及到对象的状态转换为可以存储或传输的形式,并且能够在之后将其恢复为原始形式的过程。本文将深入探讨Java序列化的各个方面,包括其概念、原理...

    什么是java序列化,如何实现java序列化?学习.pdf

    Java 序列化机制 Java 序列化机制是一种将对象状态写入 Byte 流里的技术,并可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许将对象通过网络进行传播,并可以随时把对象持久化到...

    对象序列化 串行化

    对象序列化 串行化 实现java对象的保存

    Java关键字Transient与串行化

    ### Java序列化简介 序列化是将对象的状态转换为可以存储或传输的格式的过程。在Java中,通过实现`java.io.Serializable`接口,一个类可以使其实例被序列化。当一个对象被序列化时,它的状态会被编码成一系列字节,...

    什么是java序列化,如何实现java序列化?.pdf

    Java 序列化机制 Java 序列化是将一个对象的状态写入一个 Byte 流里,并且可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到...

    java对象的串行化

    - **自定义序列化**: 通过实现`writeObject()`和`readObject()`方法,对象可以定义自己的序列化格式。 **二、实现串行化** 在Java中,实现串行化需要让类实现`Serializable`接口。这个接口没有定义任何方法,仅仅...

    什么是java序列化,如何实现java序列化?借鉴.pdf

    Java 序列化机制 Java 序列化是指将一个对象的状态写入一个 Byte 流里,并且可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到...

    java高效对象序列化反序列化工具kryo-2.21

    Kryo是一款强大的、高效且易于使用的Java序列化库,特别适合对性能有高要求的场景。在本文中,我们将深入探讨Kryo的核心特性、工作原理以及如何在实际项目中应用。 ### Kryo简介 Kryo是一个开源的序列化库,最初由...

    java 对象的xml串行化 实现网络间的类信息的传输

    总之,Java对象的XML串行化是Java开发中的一项重要技术,它通过XStream等库实现了Java对象与XML数据之间的灵活转换,从而在网络通信和分布式系统中实现了类信息的有效传输。在实际项目中,合理利用这项技术可以提高...

    KryoJava序列化和克隆框架具有快速高效自动的特点

    总的来说,Kryo作为Java序列化的一个强大工具,对于那些需要高效数据交换或持久化存储的应用,是一个理想的选择。其提供的高速度、高效率和灵活性,使得Kryo在大数据处理、游戏开发以及网络通信等场景中得到了广泛...

    【IT十八掌徐培成】Java基础第16天-03.串行化-深度复制.zip

    Java串行化是Java编程语言中的一个重要概念,用于将对象的状态转换为字节流,以便存储在磁盘上或在网络中传输。这个过程被称为对象的序列化,而将字节流恢复为对象的过程称为反序列化。在Java中,实现串行化的主要...

    Python调用序列化数据工具Protocol Buffers——protobuf

    Protocol Buffers是Google开发的一种高效的数据序列化协议,它允许开发者将结构化的数据串行化,可用于数据存储、通信协议等方面。Python作为一门广泛使用的编程语言,可以方便地集成protobuf进行数据交换。在本文中...

    串行化保存和读取数据示例.zip

    下面是一些关于Java串行化的重要知识点: 1. **序列化标识符**:每个可串行化的类都可以包含一个`private static final long serialVersionUID`字段,这个字段用于版本控制。当类的结构发生变化时,如果没有正确...

    即时聊天(序列化)

    Java中,我们可以使用Java Serializable接口来标记一个类是可序列化的。序列化不仅可以用于网络传输,还可以用于持久化存储,便于恢复对象状态。例如,客户端发送的消息对象会被序列化成字节流,然后通过网络发送到...

    CArchive 文件读写 串行化

    - 对象的序列化顺序必须与反序列化顺序一致,否则可能导致数据恢复错误。 7. **优化与性能** - 对于大对象或频繁访问的数据,考虑使用指针进行串行化,避免复制开销。 - 如果需要节省磁盘空间,可以考虑使用压缩...

    串行化和反串行化

    串行化/序列化:将java对象转换成某种格式(JVM定义的)的字节数组 串行化使用场景: 将对象用户网络间传输或者是本地化储存。 反串行化:将字节数组恢复成java对象。 package com.yongjun.io; import java.io....

    Java学生信息管理用户界面系统

    2. 对象串行输入输出:为了实现数据的持久化存储,系统采用了Java的序列化机制。对象串行化将Java对象转换为字节流,然后写入磁盘,形成DAT文件。年级和班级的数据,包括每个班级的成员信息,都在每次操作后被串行化...

    protobuf java 3.2.0 zip

    Protocol Buffers是一种高效的数据序列化协议,它允许结构化的数据序列化,类似于XML、JSON,但更小、更快、更简单。它可以用于结构化数据串行化,作为网络通信和数据存储等的接口数据格式。 描述中的"protobuf-...

    java核心技术 卷II 高级特性 第9版

    5. **序列化**:Java序列化机制允许将对象的状态转换为字节流,方便存储或网络传输。书中会介绍如何实现Serializable接口,以及反序列化时的注意事项。 6. **安全**:Java的安全模型包括类加载器、访问控制、权限和...

Global site tag (gtag.js) - Google Analytics