Java序列化的机制和原理

本文介绍了Java序列化的基本概念,包括序列化与反序列化的定义及其必要性。文章详细讲解了如何通过实现Serializable接口来使一个对象可以被序列化,并提供了序列化与反序列化的具体示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Java序列化算法透析

Serialization(序列化)是一种将对象以一连串的字节描述的过程;反序列化deserialization是一种将这些字节重建成一个对象的过程。Java序列化API提供一种处理对象序列化的标准机制。

序列化的必要性

Java中,一切都是对象,在分布式环境中经常需要将Object从这一端网络或设备传递到另一端。这就需要有一种可以在两端传输数据的协议。Java序列化机制就是为了解决这个问题而产生。

如何序列化一个对象

一个对象能够序列化的前提是实现Serializable接口,Serializable接口没有方法,更像是个标记。有了这个标记的Class就能被序列化机制处理。

import java.io.Serializable;  
 
class TestSerial implements Serializable {  
 
       public byte version = 100;  
 
       public byte count = 0;  
 
} 

 然后我们写个程序将对象序列化并输出。ObjectOutputStream能把Object输出成Byte流。我们将Byte流暂时存储到temp.out文件里。

 

public static void main(String args[]) throws IOException {  
 
       FileOutputStream fos = new FileOutputStream("temp.out");  
 
       ObjectOutputStream oos = new ObjectOutputStream(fos);  
 
       TestSerial ts = new TestSerial();  
 
       oos.writeObject(ts);  
 
       oos.flush();  
 
       oos.close();  
 
} 

 

如果要从持久的文件中读取Bytes重建对象,我们可以使用ObjectInputStream。 

public static void main(String args[]) throws IOException {  
 
       FileInputStream fis = new FileInputStream("temp.out");  
 
       ObjectInputStream oin = new ObjectInputStream(fis);  
 
       TestSerial ts = (TestSerial) oin.readObject();  
 
       System.out.println("version="+ts.version);  
 
} 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值