在maven多模块项目中,模块d无法真正“无版本号”依赖模块a/b/c;必须显式声明版本,但可通过版本范围(如[1.5,))或统一父pom管理实现自动同步最新快照,确保构建一致性。
Maven 的设计原则强调可重现构建(reproducible build),因此所有依赖(包括同一项目的其他模块)都必须明确指定版本号——这是强制要求,不存在真正意义上的“无版本依赖”。然而,有几种专业、安全且常用的方式,可让模块 D 始终使用 A/B/C 的最新可用代码,同时保持构建的确定性与可维护性:
将 A、B、C、D 纳入同一个多模块聚合项目,并共用一个父 POM(例如 parent-pom),所有子模块继承其
com.example my-project1.0.0-SNAPSHOT pom A B C D
D com.example my-project1.0.0-SNAPSHOT ../pom.xml com.example Acom.example Bcom.example C
✅ 优势:版本完全集中管控;mvn clean install 时 A/B/C 的最新 SNAPSHOT 会自动部署到本地仓库并被 D 解析;CI/CD 中稳定可靠。
虽然 Maven 支持版本范围(如 [1.5,))或特殊标记(RELEASE),官方已弃用且强烈不建议在生产项目中使用:
com.example A[1.5,)
⚠️ 风险提示:
若 A/B/C 与 D 并非同一代码库(即物理分离的独立 Maven 项目),则应:

? 总结:Maven 中没有“无版本依赖”,只有版本声明方式的差异。坚持使用统一父 POM + 继承机制,是兼顾开发敏捷性、构建可靠性与团队协作规范的唯一推荐路径。