用最简单的一个例子看maven冲突的解决办法

用最简单的一个例子看maven冲突的解决办法

一共四个module

  • conflict-main 1.0
  • conflict-a 1.0
  • conflict-b 1.0
  • conflict-b 2.0

依赖关系

  • conflict-main 1.0 → conflict-a 1.0,conflict-b 2.0
  • conflict-a 1.0 → conflict-b 1.0

代码

conflict-main 1.0

public static void main(String[] args) {
    AClass.callB2Method();
}
 

conflict-a 1.0

public class AClass{
    public static void callB2Method() {
        BClass.method2();
    }
}
 

conflict-b 1.0

public class BClass{
    public static void method1() {
        sout("method1");
    }
    @Deprecated
    public static void method2() {
        sout("method2");
    }
}
 

conflict-b 2.0

public class BClass{
    public static void method1() {
        sout("method1");
    }
}
 

报错

java.lang.NoSuchMethodError: com.flash.conflict.b.BClass.method2()V

相应的如果缺少类则会报如下错误(不再列出)

  • java.lang.NoClassDefFoundError(直接 new 一个不存在的类)
  • java.lang.ClassNotFoundException(Class.forName 等方式加载一个不存在的类)

原因

  • conflict-a 1.0 → conflict-b 1.0 有 method2 方法
  • conflict-main 1.0 → conflict-a 1.0,conflict-b 2.0 就近原则,取 b 的 version2 版本,无 method2 方法

解决办法

此处直接删除 conflict-main 1.0 → conflict-a 1.0,conflict-b 2.0 依赖即可

因为这只是一层所以直接删除,如果是很多层级的,就要考虑 exclude

总结

  • 运行时找不到方法:NoSuchMethodError
  • 运行时找不到类(直接new一个不存在的类):NoClassDefFoundError
  • 运行时找不到类(Class.forName等方式加载一个不存在的类):ClassNotFoundException
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/2714.html原文链接:https://javaforall.net

(0)
上一篇 2020年11月20日 下午5:16
下一篇 2020年11月20日 下午5:39


相关推荐

  • java 程序设计题库

    java 程序设计题库答题要求:单选题,每题只有一个正确答案,选择正确给分,不正确不给分。1、下面(A)数据类型可用于main()方法中传递的参数A、StringB、IntegerC、BooleanD、Variant2、以下的选项中能正确表示Java语言中的一个整型常量的是(B)A、12.B、-20C、1,000D、4563、下列的变量定义…

    2022年6月21日
    24
  • Java中如何输入一个数组「建议收藏」

    Java中如何输入一个数组「建议收藏」第一种方法:(不限制输入数组的长度)System.out.println(“请输入几个数并用逗号隔开:”);Scannersc=newScanner(System.in);Stringstr=sc.next().toString();String[]arr=str.split(“,”);int[]b=newint[arr.length];for(intj=0;j<b.length;j++){b[j]=Integ

    2022年6月26日
    146
  • c++反转链表中m位置到n位置的元素_环形数组最大子数组

    c++反转链表中m位置到n位置的元素_环形数组最大子数组原题链接给定一个由整数数组 A 表示的环形数组 C,求 C 的非空子数组的最大可能和。在此处,环形数组意味着数组的末端将会与开头相连呈环状。(形式上,当0 <= i < A.length 时 C[i] = A[i],且当 i >= 0 时 C[i+A.length] = C[i])此外,子数组最多只能包含固定缓冲区 A 中的每个元素一次。(形式上,对于子数组 C[i], C[i+1], …, C[j],不存在 i <= k1, k2 <= j 其中 k1 % A.leng

    2022年8月9日
    17
  • 小清新豆包AI大模型教程概述PPT模板人工智能AIGC演示幻灯片.pptxVIP

    小清新豆包AI大模型教程概述PPT模板人工智能AIGC演示幻灯片.pptxVIP

    2026年3月12日
    2
  • ifdef与endif的作用及用法

    ifdef与endif的作用及用法一般情况下 源程序中所有的行都参加编译 但是有时希望对其中一部分内容只在满足一定条件才进行编译 也就是对一部分内容指定编译的条件 这就是 条件编译 有时 希望当满足某条件时对一组语句进行编译 而当条件不满足时则编译另一组语句 nbsp 条件编译命令最常见的形式为 nbsp ifdef 标识符 nbsp 程序段 1 nbsp else nbsp 程序段 2 nbsp endif 它的作用是 当标识符已经被定义过 一般

    2026年3月20日
    3
  • mptcp的重传

    mptcp的重传开头啰嗦几句 关于 mptcp 的研究主要有两种 拥塞控制和数据包调度 关于多径的拥塞控制算法有 LIA OLIA BALIA wVegas 可以称作是耦合式的拥塞控制 为什么要采用耦合式的拥塞控制 而不是在各个子流上采用原有的 TCP 的拥塞控制算法 RENO CUBIC 呢 用学术点的话说 考虑到网络中大部分是 TCP 流 MPTCP 应该保有 TCP 友好的特性 用朴实的话说 做为一个研究项目 总要有些不同吧

    2026年1月30日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号