maven学习(六)依赖、聚合、继承

先说一下概念(个人理解的,有问题请留言):

  依赖:我要盖一座房子,就需要很多的砖,这些专就是盖房子的一个依赖。我要跑一个maven项目,需要各种各样的功能,功能实现的jar包和插件就是我的依赖。

  聚合:物以类聚嘛,你想要去xx旅游,我也想去xx旅游,咱们有相同的需求完全可以一块抱团啊。聚合就是将具有相同需求的模块聚合到一块,主要是为了模块服务的,比如我一个商品服务有单独的api的jar包,有单独的service的实现包,但是都属于商品模块的,执行编译等操作的时候就不用费劲执行两遍命令了,此时就可以聚合到一块。目的是方便构建项目~

  继承:这个好理解,老子传给儿子的就是继承。不断的提取共有部分进行管理,主要解决的是重复配置的问题,通常用于声明一些公共依赖模块、属性等。

依赖:

   依赖主要包含:依赖范围、传递性依赖、依赖优先级、依赖类型、可选依赖、排除依赖等,下面用带有注释的xml配置来描述。(注:此例非人类配置仅为说明各个属性的作用,未满18周岁同学请在父母陪同下观看)

<!-- 属性定义,类似于常量 -->
     <properties>
         <property.key>property.value</property.key>
         <!-- 归类依赖,这里例子举的不是很恰当。试想用定义了spring的某个版本,下面依赖的<version>全用变量就可以统一管理 -->
         <junit.version>3.8.1</junit.version>
     </properties>
    <!-- 依赖管理,可以依赖内部模块、也可以依赖三方jar包 -->
    <!-- 依赖命令:
            依赖树:dependency:tree
            依赖列表:dependency:list
            依赖分析:dependency:analyze
     -->
    <dependencies>
        <!-- 依赖 -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>${junit.version}</version>
            <!-- 组件的附属构件,不能在定义pom的时候直接指定,此值由插件生成,比如java-doc等,依赖的时候要指明
            <classifier></classifier> -->
            <!-- 
                依赖范围:
                    compile(默认):编译、测试、运行都有效,spring-core
                    test:测试,junit
                    provided:编译、测试,servlet-api
                    runtime:测试、运行,jdbc驱动
                    system:系统
                    import:与dependencyManagement同时使用
                传递性依赖:
                        A - B - sb.jar
                        此时A传递引用sb.jar
                依赖优先级:
                    1.第一原则,路径最近依赖原则
                        A - B - sb.jar
                        A - sb.jar        (√)
                    2.第二原则,最先声明依赖原则
                        A - B - sb.jar    (√)
                        A - C - sb.jar
             -->
            <scope>test</scope>
             <!-- 类型,一般不用显示声明,默认为jar -->
            <type>jar</type>
            <!-- 可选依赖,不会被传递 -->
            <optional>true</optional>
            <!-- 排除依赖,比如排除掉某个不想要的包 
            <exclusions>
                <exclusion>
                    <groupId>com.wang</groupId>
                    <artifactId>test123</artifactId>
                </exclusion>
            </exclusions>-->
            <!-- 引入比较特殊的jar包的时候才会使用到,通常是相同版本在不同环境下使用的jar,比如jar的名字json-lib-2.4-jdk15.jar -->
            <!-- <classifier>jdk15</classifier> -->
            <!-- 仅供系统范围使用,不鼓励使用这个元素,设置为系统的绝对路径,可以使用系统变量如${Java.home},要求<scope>元素的值为system 
            <systemPath>D:\test123.jar</systemPath>-->
        </dependency>
    </dependencies>

 

聚合:

  表现为pom.xml中的<modules>元素,注意module的配置是相对于父pom的,如:

<!-- 目录结构 
  parent
    父pom.xml
  account-email
    pom.xml
  account-persist
    pom.xml -->
<!-- 配置 -->
<modules>
  <module>../account-email</module>
  <module>../account-persist</module>
</modules>
<!-- 目录结构 
  父pom.xml
  account-email
    pom.xml
  account-persist
    pom.xml -->

<!-- 配置 --> <modules> <module>account-email</module> <module>account-persist</module> </modules>

继承:

  表现为pom.xml的<parent>元素,子pom可以继承父pom中的配置,如依赖、属性等。

  父模块只能打包为pom。

  可以继承的元素:groupId、version、description、organization、inceptionYear、url、developers、contributors、distributinManagement、issueManagement、ciManagement、scm、mailingLists、properties、dependencies、dependencyManagement、repositories、build、reporting

  感觉上面大多数都是一些扯蛋的元素,比较常用的有以下几个:

  properties:属性,类似于java的静态常量

  dependencies:依赖

  distributionManagement:部署配置,比如自定义组件的上传,会结合settings.xml里的server进行账号认证。

依赖管理(不会实际引入依赖):

  <dependencyManagement>元素,子模块引入时可以省略版本号的配置

  依赖管理scope元素可以设置为import,这个import必须结合dependencyManagement来使用。使用import通常指向一个pom文件,作用是将目标pom中的dependencyManagement配置导入合并到当前pom的dependencyManagement元素中使用。

插件管理(不会实际引入依赖):

  <pluginManagement>,只需引入插件的坐标即可,省去插件的具体配置,便于管理和维护~

  

 

posted @ 2017-03-05 20:40  鱼我所欲也  阅读(801)  评论(0编辑  收藏  举报