java对象的序列化与反序列化使用

1.Java序列化与反序列化

   Java序列化是指把Java对象转换为字节序列的过程;而Java反序列化是指把字节序列恢复为Java对象的过程。

2.为什么需要序列化与反序列化

  我们知道,当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。那么当两个Java进程进行通信时,能否实现进程间的对象传送呢?答案是可以的。如何做到呢?这就需要Java序列化与反序列化了。换句话说,一方面,发送方需要把这个Java对象转换为字节序列,然后在网络上传送;另一方面,接收方需要从字节序列中恢复出Java对象。基本原理和网络通信是一致的,通过特殊的编码方式:写入数据将对象以及其内部数据编码,存在在数组或者文件里面然后发送到目的地后,在进行解码,读出数据。OK到此显示出来为我们所用即可。

  当我们明晰了为什么需要Java序列化和反序列化后,我们很自然地会想Java序列化的好处。其好处一是实现了数据的持久化,通过序列化可以把数据永久地保存到硬盘上(通常存放在文件里),二是,利用序列化实现远程通信,即在网络上传送对象的字节序列。

3.对象序列化

  java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。只有实现了Serializable和Externalizable接口的类的对象才能被序列化。

  java.io.ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回。

 1、序列化流:把对象按照流一样的方式存入文本或者在网络中传输;  对象 ---> 流 :ObjectOutputStream
 2、反序列化流:把文本文件中的流对象数据或者网络中的流对象数据还原成对象。   流---> 对象 :ObjectInputStream//------------------------------------//第一个代码是将一个序列化对象赋值后,写到一个文件里面对应write()方法,然后再读取该文件中的数据,将该数据还原为对象read()方法。
 1 import java.io.FileInputStream;
 2 import java.io.FileNotFoundException;
 3 import java.io.FileOutputStream;
 4 import java.io.IOException;
 5 import java.io.ObjectInputStream;
 6 import java.io.ObjectOutputStream;
 7
 8 /*
 9  * 序列化流:把对象按照流一样的方式存入文本或者在网络中传输;  对象 ---> 流 :ObjectOutputStream
10  * 反序列化流:把文本文件中的流对象数据或者网络中的流对象数据还原成对象。   流---> 对象 :ObjectInputStream
11  */
12 public class ObjectStreamDemo {
13     public static void main(String[] args) throws IOException {
14         // 序列化数据其实就是把对象写到文本文件
15         //write();
16         read();
17     }
18
19     private static void read() throws IOException {
20         // 创建反序列化流对象
21         ObjectInputStream ois = new ObjectInputStream(new FileInputStream(
22                 "a.txt"));
23         // 读取,还原对象
24         try {
25             Person p = (Person) ois.readObject();
26             System.out.println(p.toString());
27         } catch (ClassNotFoundException e) {
28             // TODO Auto-generated catch block
29             e.printStackTrace();
30         }
31
32         ois.close();
33     }
34
35     private static void write() throws IOException {
36         // 创建序列化流对象
37         // public ObjectOutputStream(OutputStream out)
38         ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(
39                 "a.txt"));
40         // 创建对象
41         Person p = new Person("java", 20);
42         oos.writeObject(p);
43         // 释放资源
44         oos.close();
45     }
46 }

//------------------------------对象类

// 有的时候当我们修改了对象所属类的一点内容时,该序列化对象便不能被读取了,原因是在该对象序列化的时候系统默认给出了一个ID,一旦修改了该类该ID将会发生变化

// 读取的时候就无法匹配,因此编译器通过黄线提示我们添加一个ID,可以使默认default的ID也可以是generated的ID都可以,我一般使用generated。

 1 import java.io.Serializable;
 2
 3 /*
 4  * NotSerializableException为序列化异常,
 5  * 该类需要实现一个接口:Serializable序列化接口,该接口中并没有任何方法,仅仅作为标识。
 6  * 类似于此的没有方法的接口是标记接口
 7  *
 8  * !!!每一次去修改该类的时候都会生成一个新的序列化标识的值!,需要重新新,重新读,这是基本方法。
 9  * 想办法来固定该类的标识ID,人为设定。这样即使再次修改类的内容,只要ID固定了就可以保证,在读取的时候一直是匹配的。
10  * 增加 generated serial version ID,在类里面直接点击黄色即可,增加一个变化的ID值
11  */
12
13 /*
14  * 当有的成员变量不需要被序列化时:如何解决。
15  * 方法使用transient关键字声明不需要序列化的成员变量
16  */
17 public class Person implements Serializable{
18
19     /**
20      * serialVersionUID
21      */
22     private static final long serialVersionUID = -9164765814868887767L;
23
24     private String name;
25     private transient int age;
26
27     public Person() {
28         super();
29     }
30
31     public Person(String name, int age) {
32         super();
33         this.name = name;
34         this.age = age;
35     }
36
37     public String getName() {
38         return name;
39     }
40
41     public void setName(String name) {
42         this.name = name;
43     }
44
45     public int getAge() {
46         return age;
47     }
48
49     public void setAge(int age) {
50         this.age = age;
51     }
52
53     @Override
54     public String toString() {
55         return "Person [name=" + name + ", age=" + age + "]";
56     }
57
58 }

//上面的序列化只是简单介绍了序列化的作用,在Android开发中我们不可能为了传递一个对象重新再APK文件里面添加一个文件用来存放对象的数据,因此在Android开发室

//直接使用的是一个字符序列数组来暂时保存序列化的二进制数值。

//http://www.cnblogs.com/fuck1/p/5459660.html在这里面有详细的使用方法。

时间: 2024-10-13 12:16:37

java对象的序列化与反序列化使用的相关文章

Java基础学习总结——Java对象的序列化和反序列化

一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存.比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些s

Java对象的序列化与反序列化

我们知道Java中的对象都是存在于堆内存中的,而堆内存是可以被垃圾回收器不定期回收的.从对象被创建到被回收这一段时间就是Java对象的生命周期,也即Java对象只存活于这个时间段内. 对象被垃圾回收器回收意味着对象和对象中的成员变量所占的内存也就被回收,这意味着我们就再也得不到该对象的任何内容了,因为已经被销毁了嘛,当然我们可以再重新创建,但这时的对象的各种属性都又被重新初始化了.所以如果我们需要保存某对象的状态,然后再在未来的某段时间将该对象再恢复出来的话,则必须要在对象被销毁即被垃圾回收器回

Java对象的序列化和反序列化

一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存.比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些s

Java对象的序列化和反序列化(转)

一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存.比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些s

Java对象的序列化和反序列化实践

当两个进程在进行远程通信时,彼此可以发送各种类型的数据.无论是何种类型的数据,都会以二进制序列的形式在网络上传送.发送方需要把这个Java对象转换为字节序列,才能在网络上传送:接收方则需要把字节序列再恢复为Java对象. 把Java对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为Java对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 一. JDK类库中的序列化API j

Java对象的序列化和反序列化Serializable

1.什么是序列化和反序列化 Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization是一种将这些字节重建成一个对象的过程. 2.什么情况下需要序列化 a)当你想把的内存中的对象保存到一个文件中或者数据库中时候: b)当你想用套接字在网络上传送对象的时候: c)当你想通过RMI传输对象的时候: 3.如何实现序列化 将需要序列化的类实现Serializable接口就可以了,Serializable接口中没有任何方法,可以理解为一个标记,即表明这

[转载]Java基础学习总结——Java对象的序列化和反序列化

最近用到序列化,看到这篇文章写得很好,转载下,原文链接贴在这里了. 原文链接:http://www.cnblogs.com/xdp-gacl/p/3777987.html 一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,

Java基础学习总结--Java对象的序列化和反序列化

一.序列化和反序列化的概念 把对象转换成字节序列的过程称之为对象的序列化 把字节序列恢复为对象的过程称之为对象的反序列化 对象序列化的主要用途: 1)把对象的字节序列永久的保存到硬盘上,通常放在一个文件中: 2)在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存,比如最常见的是web服务器中的session对象,当有10万用户并发访问的时候,就可能出现10万个session对象,内存可能吃不消,于是web容器就会把一些sessio

Jedis和JAVA对象的序列化和反序列化的使用

1. Jedis版本: jedis-2.6.2.jar 背景:现在系统提供portal接口服务,使用JDBC直接查询数据库,使用jedis提供的缓存功能,在JDBC前面加上Redis,先从Redis中查询数据,如果Redis中没有该数据,就从数据库中查询,再把查询到的结果放入Redis中,下次再请求该接口的时候,就直接返回Redis中的数据. 2. 序列化和反序列化的使用 接口查询到的数据是一个List集合,把集合对象通过序列化为字符串,放入到Redis中.使用的时候取出Redis中的数据,通过