Jackson Core 3.0 模块化系统升级:从Moditect到原生module-info.java
2025-07-02 20:26:21作者:钟日瑜
在Java 9引入模块系统(JPMS)后,许多Java库都面临着如何适配模块化系统的挑战。Jackson Core作为广泛使用的JSON处理库,在2.x版本中采用了Moditect插件来实现模块化支持。随着Jackson 3.0的发布,开发团队决定转向更原生的模块化实现方式。
背景与挑战
在Jackson 2.x系列中,由于需要保持对JDK 8的兼容性,开发团队使用了Moditect插件来生成module-info.class文件。这是因为JDK 8的编译器无法处理module-info.java源文件。Moditect作为一个构建工具插件,能够在构建过程中动态添加模块描述信息,而不需要直接使用Java 9+的模块化语法。
然而,这种间接方式带来了几个问题:
- 构建过程复杂度增加
- 需要额外的构建插件依赖
- 模块描述与实际代码可能存在不一致的风险
3.0版本的改进
Jackson 3.0将最低JDK要求提升到了17,这使得开发团队能够直接使用Java的原生模块化支持。主要改进包括:
- 直接使用module-info.java:现在可以直接在源代码中包含模块描述文件,而不需要通过构建插件转换
- 简化构建配置:移除了对Moditect插件的依赖,使构建过程更加简洁
- 更好的开发体验:IDE能够直接识别模块描述文件,提供更好的开发支持
实现细节
在转换过程中,开发团队需要注意几个关键点:
- 模块描述位置:module-info.java文件应直接放在src/main/java目录下
- 多版本JAR文件:虽然3.0不再支持JDK 8,但仍需考虑模块描述在多版本JAR中的正确位置
- 构建工具兼容性:确保Maven等构建工具正确处理模块描述文件
例外情况
值得注意的是,jackson-annotations模块仍然保持JDK 8兼容性,因此继续使用Moditect方式处理模块化。这是为了保持该基础模块的广泛兼容性,因为注解模块通常被更多项目依赖。
结论
Jackson Core 3.0从Moditect转向原生module-info.java的转变,代表了Java生态向现代模块化系统的演进。这一改进不仅简化了构建过程,还提高了模块描述的准确性和可维护性,为开发者提供了更符合现代Java开发实践的体验。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0171
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook090
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
BitCPM-CANN-8BBitCPM-CANN 是首个基于华为昇腾 NPU 原生构建的端到端 1.58 位(三值化)大语言模型训练系统。该系统将量化感知训练(QAT)集成到 Megatron-LM 框架中,并结合 MindSpeed 加速,覆盖了从自定义三值算子到基于昇腾 910B 的分布式并行训练的完整训练栈。Python00
MiniCPM5-1BMiniCPM5-1B,这是 MiniCPM5 系列的首款模型。它是一个专为端侧、本地部署和资源受限场景打造的 10 亿参数密集型 Transformer 模型,达到了 10 亿参数级开源模型的 SOTA 水平Jinja00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0239
项目优选
收起
暂无描述
Dockerfile
748
4.85 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
831
1.82 K
Ascend Extension for PyTorch
Python
682
823
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
640
1.25 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
448
412
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.02 K
1.03 K
昇腾LLM分布式训练框架
Python
172
211
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.48 K
171
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
147
241
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
927
553