0

0

解决 Java 序列化中父类字段不可序列化的根本问题

花韻仙語

花韻仙語

发布时间:2026-02-25 13:57:10

|

215人浏览过

|

来源于php中文网

原创

解决 Java 序列化中父类字段不可序列化的根本问题

本文详解为何在子类实现 Serializable 后仍抛出 NotSerializableException,核心原因在于继承链中非 Serializable 的超类成员(如 eventList)所引用的对象(如 Event 实例)未实现序列化接口,并提供完整、可落地的修复方案。

本文详解为何在子类实现 `serializable` 后仍抛出 `notserializableexception`,核心原因在于继承链中非 `serializable` 的超类成员(如 `eventlist`)所引用的对象(如 `event` 实例)未实现序列化接口,并提供完整、可落地的修复方案。

在 Java 序列化机制中,一个对象能否被成功序列化,不仅取决于其自身是否实现了 Serializable 接口,更取决于其所有可访问的非瞬态(non-transient)实例字段所引用的对象类型——这些类型也必须是可序列化的。本案例中,GreenhouseControls 虽已声明 implements Serializable,但其继承自 Controller 的 protected List eventList 字段中存储的是大量 Event 子类实例(如 WindowMalfunction、PowerOut),而 Event 抽象类本身未实现 Serializable。这导致 JVM 在尝试序列化 eventList 中的每个 Event 对象时失败,最终抛出 java.io.NotSerializableException: GreenhouseControls$WindowMalfunction。

✅ 正确解决方案:确保整个对象图可序列化

最直接、最符合 Java 序列化契约的修复方式,是让 Event 类及其所有子类处于可序列化体系内:

// ✅ 修改 Event.java:添加 implements Serializable
public abstract class Event implements Serializable {
    private static final long serialVersionUID = 1L; // 强烈建议显式声明

    private long eventTime;
    protected final long delayTime;

    public Event(long delayTime) {
        this.delayTime = delayTime;
        start();
    }

    public void start() {
        eventTime = System.currentTimeMillis() + delayTime;
    }

    public boolean ready() {
        return System.currentTimeMillis() >= eventTime;
    }

    public abstract void action() throws ControllerException;
}

? 关键点说明:

  • serialVersionUID 是最佳实践:显式声明可避免因编译器自动生成差异导致反序列化失败;
  • 所有 Event 的子类(如 WindowMalfunction、PowerOut)将自动继承可序列化能力,无需重复实现 Serializable;
  • Controller 和 GreenhouseControls 无需额外修改(Controller 本身不必实现 Serializable,因为其字段 eventList 的元素类型已可序列化)。

⚠️ 为什么其他尝试会失败?

  • 仅让 Controller 实现 Serializable:无效。Controller 并未持有 eventList 中对象的序列化责任;JVM 检查的是 eventList 元素(即 Event 实例)的类型,而非容器类。
  • 自定义 writeObject/readObject:虽能手动写出 super.eventList,但 out.writeObject(super.eventList) 内部仍会递归序列化每个 Event 元素——若 Event 不可序列化,异常照常抛出,自定义逻辑无法绕过该检查。

? 补充验证:确保无遗漏依赖

除 Event 外,请确认以下类型也实现了 Serializable(如有自定义类参与事件逻辑):

PHP轻论坛
PHP轻论坛

简介PHP轻论坛是一个简单易用的PHP论坛程序,适合小型社区和个人网站使用。v3.0版本是完全重构的版本,解决了之前版本中的所有已知问题,特别是MySQL保留字冲突问题。主要特点• 简单易用:简洁的界面,易于安装和使用• 响应式设计:适配各种设备,包括手机和平板• 安全可靠:避免使用MySQL保留字,防止SQL注入• 功能完善:支持分类、主题、回复、用户管理等基本功能• 易于扩展:模块化设计,便于

下载

立即学习Java免费学习笔记(深入)”;

  • ControllerException(若含自定义字段,建议实现 Serializable);
  • FixWindow、PowerOn 等 Fixable 实现类(若被序列化字段引用);
  • Event 中可能引用的任何其他业务对象(如传感器状态类)。

✅ 最终效果

修复后,serializeObject(gc) 将成功将完整的 GreenhouseControls 对象(含从 Controller 继承的 eventList 及其中全部 Event 子类实例)持久化至 dump.out 文件。后续可通过标准反序列化恢复运行状态:

public static GreenhouseControls deserializeObject() {
    try (FileInputStream fileIn = new FileInputStream("dump.out");
         ObjectInputStream in = new ObjectInputStream(fileIn)) {
        return (GreenhouseControls) in.readObject();
    } catch (IOException | ClassNotFoundException e) {
        e.printStackTrace();
        return null;
    }
}

? 总结:Java 序列化是“全有或全无”的深度遍历过程。解决 NotSerializableException 的本质,不是绕过限制,而是补全整个对象图中每一环的序列化契约。从 Event 接口/抽象类入手,是最简洁、最健壮、最符合设计原则的正解。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

智谱清言 - 免费全能的AI助手
智谱清言 - 免费全能的AI助手

智谱清言 - 免费全能的AI助手

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1651

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

506

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2308

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

40

2026.01.19

传感器故障解决方法
传感器故障解决方法

传感器故障排除指南:识别故障症状(如误读或错误代码)。检查电源和连接(确保连接牢固,无损坏)。校准传感器(遵循制造商说明)。诊断内部故障(目视检查、信号测试、环境影响评估)。更换传感器(选择相同规格,遵循安装说明)。验证修复(检查信号准确性,监测异常行为)。

486

2024.06.04

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

36

2026.02.25

Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法
Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法

本专题系统整理Steam官网最新可用入口,涵盖网页版登录地址、新用户注册流程、账号登录方法及官方游戏商店访问说明,帮助新手玩家快速进入Steam平台,完成注册登录并管理个人游戏库。

2

2026.02.25

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

0

2026.02.25

Python数据处理流水线与ETL工程实战
Python数据处理流水线与ETL工程实战

本专题聚焦 Python 在数据工程场景下的实际应用,系统讲解 ETL 流程设计、数据抽取与清洗、批处理与增量处理方案,以及数据质量校验与异常处理机制。通过构建完整的数据处理流水线案例,帮助开发者掌握数据工程中的性能优化思路与工程化规范,为后续数据分析与机器学习提供稳定可靠的数据基础。

0

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.9万人学习

C# 教程
C# 教程

共94课时 | 10.2万人学习

Java 教程
Java 教程

共578课时 | 72.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号