Java中什么是序列化和反序列化?为什么要序列化?

序列化与反序列化的概念:

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

序列化分为两大部分:序列化和反序列化。

  • 序列化:对象序列化的最主要的用处就是在传递和保存对象的时候,保证对象的完整性和可传递性。序列化是把对象转换成有序字节流,以便在网络上传输或者保存在本地文件中。核心作用是对象状态的保存与重建。

  • 反序列化:客户端从文件中或网络上获得序列化后的对象字节流,根据字节流中所保存的对象状态及描述信息,通过反序列化重建对象。

为什么需要序列化与反序列化?

为什么要序列化,那就是说一下序列化的好处喽,序列化有什么什么优点,所以我们要序列化。

一:对象序列化可以实现分布式对象。

主要应用例如:RMI(即远程调用Remote Method Invocation)要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。

二:java对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。

可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的"深复制",即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列。

三:序列化可以将内存中的类写入文件或数据库中。

比如:将某个类序列化后存为文件,下次读取时只需将文件中的数据反序列化就可以将原先的类还原到内存中。也可以将类序列化为流数据进行传输。

总的来说就是将一个已经实例化的类转成文件存储,下次需要实例化的时候只要反序列化即可将类实例化到内存中并保留序列化时类中的所有变量和状态。

四:对象、文件、数据,有许多不同的格式,很难统一传输和保存。

序列化以后就都是字节流了,无论原来是什么东西,都能变成一样的东西,就可以进行通用的格式传输或保存,传输结束以后,要再次使用,就进行反序列化还原,这样对象还是对象,文件还是文件。

如何做到?这就需要Java序列化与反序列化了。

通俗来讲就是,一方面,发送方需要把这个Java对象转换为字节序列,然后在网络上传送;另一方面,接收方需要从字节序列中恢复出Java对象。

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

序列化高级认识下方链接:

《Java 序列化的高级认识》
IBM Developer

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java序列化反序列化是将对象转换为字节流以便存储或传输,并在需要时将字节流重新转换为对象的过程[^1]。序列化可以将对象保存到文件或通过网络传输,而反序列化则可以从文件或网络读取字节流并重新构建对象。 序列化的主要作用是实现对象的持久化存储和跨网络传输。当需要将对象保存到磁盘或数据库,或者在不同的Java虚拟机之间传输对象时,就需要使用序列化。通过序列化,可以将对象转换为字节流,然后再将字节流写入文件或通过网络传输。反序列化则是将字节流重新转换为对象,以便在需要时重新使用对象。 在Java,可以通过实现Serializable接口来使一个类可序列化。Serializable接口是一个标记接口,没有任何方法需要实现。只要一个类实现了Serializable接口,就可以将该类的对象序列化反序列化。需要注意的是,被序列化的类的所有成员变量都会被序列化,包括私有成员变量。但是,被声明为static和transient的成员变量不能被序列化。static成员变量是描述类级别的属性,而transient关键字表示临时数据,不需要被序列化Java提供了ObjectOutputStream和ObjectInputStream类来实现序列化反序列化。通过ObjectOutputStream的writeObject()方法可以将对象序列化为字节流,而通过ObjectInputStream的readObject()方法可以将字节流反序列化为对象。 范例: ```java import java.io.*; public class SerializationDemo { public static void main(String[] args) { // 序列化对象 try { // 创建一个Person对象 Person person = new Person("Alice", 25); // 创建一个ObjectOutputStream对象 ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("person.ser")); // 将person对象写入文件 oos.writeObject(person); // 关闭ObjectOutputStream oos.close(); System.out.println("Person对象已序列化"); } catch (IOException e) { e.printStackTrace(); } // 反序列化对象 try { // 创建一个ObjectInputStream对象 ObjectInputStream ois = new ObjectInputStream(new FileInputStream("person.ser")); // 从文件读取对象 Person person = (Person) ois.readObject(); // 关闭ObjectInputStream ois.close(); System.out.println("反序列化得到的Person对象:"); System.out.println("姓名:" + person.getName()); System.out.println("年龄:" + person.getAge()); } catch (IOException | ClassNotFoundException e) { e.printStackTrace(); } } } class Person implements Serializable { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值