51Testing软件测试论坛

标题: Maven系列--"maven-compiler-plugin"的使用 [打印本页]

作者: 歪小Y_02    时间: 2019-3-7 16:25
标题: Maven系列--"maven-compiler-plugin"的使用

maven是个项目管理工具,如果我们不告诉它我们的代码要使用什么样的jdk版本编译的话,它就会用maven-compiler-plugin默认的jdk版本来进行处理,这样就容易出现版本不匹配的问题,以至于可能导致编译不通过的问题。例如代码中要是使用上了jdk1.7的新特性,但是maven在编译的时候使用的是jdk1.6的版本,那这一段代码是完全不可能编译成.class文件的。为了处理这一种情况的出现,在构建maven项目的时候,我习惯性第一步就是配置maven-compiler-plugin插件。

下面看一下这个插件该怎么使用

  1. <plugin>
  2.     <groupId>org.apache.maven.plugins</groupId>
  3.     <artifactId>maven-compiler-plugin</artifactId>
  4.     <version>3.1</version>
  5.     <configuration>
  6.         <source>1.6</source> <!-- 源代码使用的开发版本 -->
  7.         <target>1.6</target> <!-- 需要生成的目标class文件的编译版本 -->
  8.         <!-- 一般而言,target与source是保持一致的,但是,有时候为了让程序能在其他版本的jdk中运行(对于低版本目标jdk,源代码中需要没有使用低版本jdk中不支持的语法),会存在target不同于source的情况 -->
  9.    
  10.         <!-- 这下面的是可选项 -->
  11.         <meminitial>128m</meminitial>
  12.         <maxmem>512m</maxmem>
  13.         <fork>true</fork> <!-- fork is enable,用于明确表示编译版本配置的可用 -->
  14.         <compilerVersion>1.3</compilerVersion>
  15.         
  16.         <!-- 这个选项用来传递编译器自身不包含但是却支持的参数选项 -->
  17.         <compilerArgument>-verbose -bootclasspath ${java.home}\lib\rt.jar</compilerArgument>
  18.         
  19.     </configuration>
  20. </plugin>
复制代码

很多时候,大家都喜欢在eclipse中直接生成webapp的maven项目,但是这样子会产生很多问题,特别是使用的jdk不是maven默认支持的jdk的时候。

一般情况下,我是先建立一个最基本的maven项目,类型如下

  1. <packaging>jar</packaging>
复制代码

然后设置好jdk版本,再改为

  1. <packaging>war</packaging>
复制代码

再用eclipse update一下maven项目,eclipse的maven插件自会帮我们建立好此webapp在当前jdk下支持的各种默认参数,然后再优调一下就可以使用了,会省去很多麻烦事。







欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2