今年大四了,拼命做笔试题,看到了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-prj 项目中,可能包含了各种示例代码,展示了如何在Java中实现和使用序列化功能。...
### Java序列化详解 在Java开发中,序列化是一个非常重要的概念,它涉及到对象的状态转换为可以存储或传输的形式,并且能够在之后将其恢复为原始形式的过程。本文将深入探讨Java序列化的各个方面,包括其概念、原理...
Java 序列化机制 Java 序列化机制是一种将对象状态写入 Byte 流里的技术,并可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许将对象通过网络进行传播,并可以随时把对象持久化到...
对象序列化 串行化 实现java对象的保存
### Java序列化简介 序列化是将对象的状态转换为可以存储或传输的格式的过程。在Java中,通过实现`java.io.Serializable`接口,一个类可以使其实例被序列化。当一个对象被序列化时,它的状态会被编码成一系列字节,...
Java 序列化机制 Java 序列化是将一个对象的状态写入一个 Byte 流里,并且可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到...
- **自定义序列化**: 通过实现`writeObject()`和`readObject()`方法,对象可以定义自己的序列化格式。 **二、实现串行化** 在Java中,实现串行化需要让类实现`Serializable`接口。这个接口没有定义任何方法,仅仅...
Java 序列化机制 Java 序列化是指将一个对象的状态写入一个 Byte 流里,并且可以从其它地方把该 Byte 流里的数据读出来,重新构造一个相同的对象。这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到...
Kryo是一款强大的、高效且易于使用的Java序列化库,特别适合对性能有高要求的场景。在本文中,我们将深入探讨Kryo的核心特性、工作原理以及如何在实际项目中应用。 ### Kryo简介 Kryo是一个开源的序列化库,最初由...
总之,Java对象的XML串行化是Java开发中的一项重要技术,它通过XStream等库实现了Java对象与XML数据之间的灵活转换,从而在网络通信和分布式系统中实现了类信息的有效传输。在实际项目中,合理利用这项技术可以提高...
总的来说,Kryo作为Java序列化的一个强大工具,对于那些需要高效数据交换或持久化存储的应用,是一个理想的选择。其提供的高速度、高效率和灵活性,使得Kryo在大数据处理、游戏开发以及网络通信等场景中得到了广泛...
Java串行化是Java编程语言中的一个重要概念,用于将对象的状态转换为字节流,以便存储在磁盘上或在网络中传输。这个过程被称为对象的序列化,而将字节流恢复为对象的过程称为反序列化。在Java中,实现串行化的主要...
Protocol Buffers是Google开发的一种高效的数据序列化协议,它允许开发者将结构化的数据串行化,可用于数据存储、通信协议等方面。Python作为一门广泛使用的编程语言,可以方便地集成protobuf进行数据交换。在本文中...
下面是一些关于Java串行化的重要知识点: 1. **序列化标识符**:每个可串行化的类都可以包含一个`private static final long serialVersionUID`字段,这个字段用于版本控制。当类的结构发生变化时,如果没有正确...
Java中,我们可以使用Java Serializable接口来标记一个类是可序列化的。序列化不仅可以用于网络传输,还可以用于持久化存储,便于恢复对象状态。例如,客户端发送的消息对象会被序列化成字节流,然后通过网络发送到...
- 对象的序列化顺序必须与反序列化顺序一致,否则可能导致数据恢复错误。 7. **优化与性能** - 对于大对象或频繁访问的数据,考虑使用指针进行串行化,避免复制开销。 - 如果需要节省磁盘空间,可以考虑使用压缩...
串行化/序列化:将java对象转换成某种格式(JVM定义的)的字节数组 串行化使用场景: 将对象用户网络间传输或者是本地化储存。 反串行化:将字节数组恢复成java对象。 package com.yongjun.io; import java.io....
2. 对象串行输入输出:为了实现数据的持久化存储,系统采用了Java的序列化机制。对象串行化将Java对象转换为字节流,然后写入磁盘,形成DAT文件。年级和班级的数据,包括每个班级的成员信息,都在每次操作后被串行化...
Protocol Buffers是一种高效的数据序列化协议,它允许结构化的数据序列化,类似于XML、JSON,但更小、更快、更简单。它可以用于结构化数据串行化,作为网络通信和数据存储等的接口数据格式。 描述中的"protobuf-...
5. **序列化**:Java序列化机制允许将对象的状态转换为字节流,方便存储或网络传输。书中会介绍如何实现Serializable接口,以及反序列化时的注意事项。 6. **安全**:Java的安全模型包括类加载器、访问控制、权限和...