news 2026/4/17 8:17:25

Maven 4 要来了:15 年后,Java 构建工具迎来“彻底重构”

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Maven 4 要来了:15 年后,Java 构建工具迎来“彻底重构”

2010 年 Maven 3 发布以来,Maven 对 Java 构建生态的整体支持方式,几乎没有发生过颠覆性的变化。

然而在这 15 年里,Java 世界早已天翻地覆:

•模块化成为标配•并行构建成为刚需•云原生与容器化成为主流•JDK 以一年两个大版本的节奏持续快速演进

相比之下,Maven 本身却显得有些“老态”。

Maven 4 的出现,正是为了解决这些长期积累的历史包袱。

虽然 Maven 4 仍未公布正式 GA 发布日期,但目前已经迭代到第五个发布候选版本(RC5),从项目成熟度和变更稳定性来看,距离正式发布已相当接近。

现在正是提前了解、评估和准备升级的合适时机。


POM 模型升级:从 4.0.0 到 4.1.0

Maven 4 将 POM 的模型版本升级为4.1.0

<projectxmlns="http://maven.apache.org/POM/4.1.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.1.0http://maven.apache.org/xsd/maven-4.1.0.xsd"><modelVersion>4.1.0</modelVersion></project>

向后兼容:Maven 4 仍然可以构建 4.0.0 的 POM•新能力只对 4.1.0 生效modelVersion理论上可以省略,Maven 会从 schema 推导

也就是说:

不升级 POM 也能用 Maven 4,但升级后才能真正“吃到红利”。


Build POM / Consumer POM 分离:终于解决“POM 污染”

这是 Maven 4最重要、也是最颠覆性的变化之一。

在 Maven 3 中,发布到仓库的 POM 同时包含:

•插件配置•构建细节•父 POM 引用•各种属性

依赖使用者会被迫解析大量“与我无关”的信息。

Maven 4 的解决方法是POM 扁平化(Flattening)

Maven 4 正式区分:

类型

用途

Build POM

项目自身构建

Consumer POM

提供给依赖方

Consumer POM 具备以下特征:

•不包含插件配置•不包含父 POM•不包含未使用依赖•只保留真实传递依赖•属性已被解析为具体值

开启方式:

    mvn clean install -Dmaven.consumer.pom.flatten=true

    Maven 3 时代需要额外的 Flatten Maven Plugin,Maven 4 中已成为原生能力

    这一步,直接让依赖解析更快、更干净、更可预测。


    新 Artifact Type:显式控制 classpath / module path

    在 Maven 3 中:

    •普通 JAR → classpath•含module-info.class→ module path(自动推断)

    这种“隐式规则”在 Java 模块化时代并不够清晰。

    Maven 4 新增类型:

    <type>classpath-jar</type><type>module-jar</type>

    开发者终于可以显式声明依赖放在哪里

    Maven 4 还新增了专门的注解处理器类型:

    processorclasspath-processormodular-processor

    以 Lombok 为例:

    <dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>${lombok.version}</version><type>classpath-processor</type></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>${lombok.version}</version><scope>provided</scope></dependency></dependencies>

    Maven 4明确区分了 API classpath 与 processor classpath,构建语义更清晰,也更利于工具链优化。


    Modules 改名为 Subprojects:为 Java 9 “让路”

    Java 9 引入模块系统后:

    Maven ModulesJava Modules

    长期让新手和工具“集体懵逼”。

    Maven 4 的选择是:

    modulessubprojectsmodules标记为 deprecated

    <subprojects><subproject>project-a</subproject><subproject>project-b</subproject></subprojects>

    同时还支持:

    Parent 推断:空<parent />自动识别•子项目自动发现:无需显式声明•统一构建时间戳安全发布:子项目失败 → 全部不发布

    这是一次语义层面 + 工程实践层面的双重升级。


    树形生命周期:并行构建终于“名正言顺”

    Maven 3 的生命周期是线性的,即使多模块,也很难高效并行。

    Maven 4 引入Tree-based Lifecycle

    •每个子项目独立推进生命周期•依赖就绪即可启动•大型多模块构建速度显著提升

    开启方式:

      mvn -b concurrent verify

      配置能力显著增强的“小变化”

      1. 条件表达式 Profile

      <condition>exists('${project.basedir}/src/**/*.xsd')&& length(${user.name}) > 5</condition>

      不再只是os.namejdk这种基础判断,而是真正的表达式系统

      2. 统一的 Sources 模型

      Maven 3:

        <sourceDirectory>...</sourceDirectory><testSourceDirectory>...</testSourceDirectory>

        Maven 4:

        <sources><source><scope>main</scope><directory>my-custom-dir/foo</directory></source><source><scope>test</scope><directory>my-custom-dir/bar</directory></source></sources>

        更适合:

        •多目录•多版本•模块化项目•无插件配置场景


        Maven 4 还提供了官方升级工具:

        mvnup check # 只生成报告mvnup apply # 自动修改

        它会分析:

        •POM•插件•项目结构

        并给出可执行的升级建议

        版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
        网站建设 2026/4/17 19:47:29

        收藏!AI Agent 实战指南:从0到1搞懂大模型落地核心能力

        做 AI 开发、入门大模型的程序员或小白&#xff0c;是不是都遇过这样的瓶颈&#xff1a;用大模型写接口、解算法题信手拈来&#xff0c;可一旦碰到“批量爬取竞品数据并生成可视化分析报告”“自动化完成接口全流程测试输出可复用测试用例”这类实战场景&#xff0c;就瞬间卡壳…

        作者头像 李华
        网站建设 2026/4/12 22:44:39

        8个降aigc工具推荐!继续教育学员必看的高效降AI率方案

        8个降aigc工具推荐&#xff01;继续教育学员必看的高效降AI率方案 AI降重工具&#xff1a;让论文更自然&#xff0c;让学术更安心 在当前的学术环境中&#xff0c;AI生成内容&#xff08;AIGC&#xff09;已被广泛应用于论文写作中&#xff0c;但随之而来的高AI痕迹和查重率问题…

        作者头像 李华
        网站建设 2026/4/18 4:29:58

        如何搭建自动化测试框架?

        &#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 最近好多小伙伴都在说接口自动化测试&#xff0c;那么究竟什么是接口自动化测试呢&#xff1f;让我们一起往下看就知道了&#xff0c;首先我们得先弄清楚下面这…

        作者头像 李华
        网站建设 2026/4/8 9:02:33

        java_ssm120选课成绩教案管理系统_idea项目源码

        目录 具体实现截图项目概述技术架构核心功能数据库设计项目亮点部署说明 系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 项目概述 Java SSM120选课成绩教案管理系统是基于SSM&#xff08;Spri…

        作者头像 李华
        网站建设 2026/4/2 12:52:27

        【2026年最新整理】网络安全系统教程+渗透测试+学习路线

        一、什么是网络安全 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 无论网络、Web、移动、桌面、云等哪个领域&#xff0c;都有攻与防两面…

        作者头像 李华
        网站建设 2026/4/11 16:14:06

        java_ssm8中药中草药商城 供求信息管理系统_idea项目源码

        目录 具体实现截图项目背景与目标技术架构核心功能模块创新与优势适用场景总结 系统所用技术介绍写作提纲源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 具体实现截图 项目背景与目标 中药中草药商城供求信息管理系统基于Java SSM框…

        作者头像 李华