java.lang.io包 Serializable

本文介绍了Java序列化的概念及其过程,包括序列化与反序列化的原理。详细解释了序列化的特性,如类与子类的序列化能力、static和transient字段的排除、以及通过serialVersionUID确保版本一致性的重要性。

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

序列化是什么:序列化就是将一个对象的状态(各个属性量)保存起来,然后在适当的时候再获得。
序列化分为两大部分:序列化和反序列化。序列化是这个过程的第一部分,将数据分解成字节流,以便存储在文件中或在网络上传输。反序列化就是打开字节流并重 构对象。对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。恢复数据要求有恢复数据的对象实例序列化的什么特点:如果某个类能够被序列 化,其子类也可以被序列化。声明为static和transient类型的成员数据不能被序列化。因为static代表类的状态, transient代表对象的临时数据。
简单来说,Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。
在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,
如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。

当实现java.io.Serializable接口的实体(类)没有显式地定义一个名为serialVersionUID,
类型为long的变量时,Java序列化机制会根据编译的class自动生成一个serialVersionUID作序列化版本比较用,
这种情况下,只有同一次编译生成的class才会生成相同的serialVersionUID 。

package com.test;

import java.io.Serializable;

public class Test1 implements Serializable {

private String name = "my name is a";
private Test2 b = null;

Test1 () {
b = new Test2 ();
}

public Test2 getB() {
return b;
}

public void setB(Test2 b) {
this.b = b;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public String show() {
return "a.toString <a.name=\"" + this.name + "\" a.b.name=\""
+ this.b.getName() + "\">" + "\na=" + this.toString() + " b="
+ this.b.toString();
}
}


public class Test2 implements Serializable{
private String name = "my name is Test2";

Test2 () {
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}
}

这样就可以写读数据了
但如果test1、test2有一个没有实现Serializable接口的话,就会出现java.io.NotSerializableException:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值