关于Java中Serializable的一些问题

本文探讨了Java中Serializable接口的作用,详细解释了serialVersionUID的重要性,包括其在序列化和反序列化过程中的角色。如果不指定serialVersionUID,类的修改可能导致反序列化失败。此外,还讨论了序列化时的继承问题和非Serializable成员变量的处理策略。

       在面试中我常常会考察Serializable相关的问题,我认为这是一个很基础的知识点,是对候选人基础是否扎实的考察。但是结果有点出乎意料,候选人往往只是知道它和序列化有关,而对于其中的细节以及更深层次的原理都不是很清楚。因此,我决定整理一下Serializable相关的一些问题,希望能够对不了解的同学有所帮助。

       一个类实现Serializable接口后可以被序列化。这个接口没有方法和字段,只是用来标志这个类可以被序列化。

关于serialVersionUID

       一个类如果实现了Serializable接口,同时也需要定义一个serialVersionUID,如下:

private static final long serialVersionUID = 1L;

        我相信很多同学一直不太明白这个 serialVersionUID 字段的真正作用,如果我们不去定义它会有什么样的问题。

        serialVersionUID按照字面意思来理解就是序列化的版本号,这个serialVersionUID是用来辅助对象的序列化与反序列化的,原则上序列化后的数据当中的serialVersionUID与当前类中的serialVersionUID一致,该对象才能被反序列化成功。

        这个serialVersionUID的工作原理大致是这样的:在序列化的时候系统将serialVersionUID写入到序列化的文件中去,反序列化的时候系统会先去检测文件中的serialVersionUID是否跟当前的serialVersionUID一致,如果一致就反序列化成功,否则就说明当前类跟序列化后的类发生了变化,反序列化时就会发生crash,并且会抛出异常:

       如果我们没有指定serialVersionUID,那么对象在被序列化的时候,系统会根据类名、变量等信息自动生成一个serialVersionUID,如果我们修改了对象的成员,那么这个serialVersionUID就会发生变化。当对象被反序列化的时候,这两个值不相等,就会发生crash。

       因此,如果我们需要对象在序列化后的改变不影响反序列化,就必须明确指定类的serialVersionUID。

继承问题

       如果父类实现了serializable接口,那么子类实现还是不实现接口都一样能够被序列化。

       如果一个类可被序列化,如果该类有父类,父类实现了Serializable则父类对象字段可以序列化,没实现,则父类对象字段不能被序列化。  、

       如果父类定义了serialVersionUID,子类也是需要定义自己的serialVersionUID。

成员变量的序列化问题

       如果一个类实现了Serializable接口,但是它内部有成员变量并不是Serializable类型的,如果我们去序列化这个类的对象,就会抛出下面的异常:

       解决的办法是让这个成员变量也实现Serializable接口,或者选择用transient去修饰这个成员变量,在序列化的时候就会忽略这个变量。

 

欢迎关注我的微信公众号,收到最新的推送文章

设置 el-table 表格滑过的样式,有以下几种常见方法: ### 改变鼠标滑过背景色 通过 CSS 覆盖默认样式,可改变表格鼠标滑过的背景色。示例代码如下: ```css /* 覆盖表格鼠标滑过的背景色 */ .el-table .el-table__body tr:hover > td { background-color: inherit; /* 继承父元素背景色或者指定为初始背景色 */ } ``` 此代码将表格鼠标滑过的背景色设置为继承父元素背景色,也可指定其他颜色值,如 `#f0f0f0` 等。 ### 动态改变有固定列的表格选中滑过样式 在 vue2 中,若要动态改变有固定列的 el-table 表格选中滑过的样式,可在 style 部分定义相关样式: ```css /deep/ .select-special-row { background-color: #b7f5e2; } /deep/ .select-common-row { background-color: #E8FBFF; } /deep/ .el-table__body .el-table__row.special-row.hover-row td { background-color: #89ebd1 !important; } /deep/ .el-table__body .el-table__row.common-row.hover-row td { background-color: #f2f3f5 !important; } /* 防止在表格选中以后鼠标移上去选中的颜色又变成原来 el-table 自带的颜色 */ /deep/ .el-table__body .el-table__row.select-special-row.hover-row td { background-color: transparent !important; } /deep/ .el-table__body .el-table__row.select-common-row.hover-row td { background-color: transparent !important; } ``` 这些样式定义了不同类型选中及其滑过状态的背景色,确保在选中和滑过状态下样式的正确显示。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值