IDEA的Maven Show Dependency使用心得

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/daerzei/article/details/82344569

在Idea Indexing和resolve Dependency的时候是不能查看Show Dependency的。

你就算只引一个包它也会有依赖冲突,

Alt加鼠标可以放大看,但是Alt放开的时候放大镜有时候并不会消失,这个时候可以继续按Alt键,鼠标移动到空白的地方待放大镜消失再松开Alt镜

红色实线表示有jar包依赖冲突,一般是版本冲突。点击冲突的jar包,IDEA会把所有引用到这个jar包的地方再以红色虚线连接起来,并高亮连接线。不点的话红色虚线是不显示出来的。
IDEA的Maven Show Dependency使用心得_01.png
我这边做测试只引了一个jar包spark-hive_2.11,这个jar包直接依赖的是spark-sql,spark-core,hive-exec,hive-metastore这是第一级依赖,第二级依赖:hadoop-common,hadoop-hdfs,hadoop-annotations竺,然后层层依赖,最后依赖到最底层的jar包,比如说apache-commons-(io/lang/lang3/beanutils/codec),guava,scala-(library/compiler/p/),log4j等等。于是Maven又自动把这些依赖的jar包引了进来。
虽然只引了这么一个jar包,但是依然有jar包依赖冲突,比如说有的jar包依赖于Scala2.11.8与有的jar包依赖于Scala2.11.7
如果这些冲突的jar包API没有变的话是没有影响的, 但是如果API变的话那就有影响了,比如说guava18.0以后有些API就发生了变化,这个时候就不得不降低guava的版本了。

右键点击exclude可以把这个有冲突的jar包排除掉
IDEA的Maven Show Dependency使用心得_02.png
IDEA会自动同步更新pom.xml配置文件。
不过IDEA的show Depentency搞耗性能的,如果你电脑配置不怎么样的话这么搞可能不管用,这个时候就需要你手动排除了,在pom.xml配置文件对应的依赖包里加上如下配置:

<exclusions>
    <exclusion>
        <groupId>org.scala-lang</groupId>
        <artifactId>scala-library</artifactId>
    </exclusion>
</exclusions>

IDEA的Maven Show Dependency使用心得_03.png
再回到Show Dependency视图,会自动更新的。

不要老想着把那些红线排除掉,排除不完的,可能我有些代码洁癖吧,看到这些红色就觉得浑身不爽,花了三天的时候把它们排除掉,最后头都搞大了,红线还是不少。

猜你喜欢

转载自blog.csdn.net/daerzei/article/details/82344569