Java构建工具:Ant vs Maven vs Gradle

转载:http://blog.csdn.net/napolunyishi/article/details/39345995
Java构建工具:Ant vs Maven vs Gradle
分类: 工具/中间件 2014-09-18 11:43 6513人阅读 评论(0) 收藏 举报
gradlejavaantmaven
目录(?)[+]
创世之初,世上只有Make一种构建工具,后来,其发展为GNU Make。但是,由于需求的不断涌现,码农的世界里逐渐演化出了千奇百怪的构建工具。
当前,JVM生态圈由三大构建工具所统治:
Apache Ant带着Ivy
Maven
Gradel
Ant with Ivy
Ant是第一个“现代”构建工具,在很多方面它有些像Make。2000年发布,在很短时间内成为Java项目上最流行的构建工具。它的学习曲线很缓,因此不需要什么特殊的准备就能上手。它基于过程式编程的idea。在最初的版本之后,逐渐具备了支持插件的功能。
主要的不足是用XML作为脚本编写格式。 XML,本质上是层次化的,并不能很好地贴合Ant过程化编程的初衷。Ant的另外一个问题是,除非是很小的项目,否则它的XML文件很快就大得无法管理。
后来,随着通过网络进行依赖管理成为必备功能,Ant采用了Apache Ivy。
Ant的主要优点在于对构建过程的控制上。

Maven
Maven发布于2004年。目的是解决码农使用Ant所带来的一些问题。
Maven仍旧使用XML作为编写构建配置的文件格式,但是,文件结构却有巨大的变化。Ant需要码农将执行task所需的全部命令都一一列出,然而Maven依靠约定(convention)并提供现成的可调用的目标(goal)。不仅如此,有可能最重要的一个补充是,Maven具备从网络上自动下载依赖的能力(Ant后来通过Ivy也具备了这个功能),这一点革命性地改变了我们开发软件的方式。
但是,Maven也有它的问题。依赖管理不能很好地处理相同库文件不同版本之间的冲突(Ivy在这方面更好一些)。XML作为配置文件的格式有严格的结构层次和标准,定制化目标(goal)很困难。因为Maven主要聚焦于依赖管理,实际上用Maven很难写出复杂、定制化的构建脚本,甚至不如Ant。
用XML写的配置文件会变得越来越大,越来越笨重。在大型项目中,它经常什么“特别的”事还没干就有几百行代码。
Maven的主要优点是生命周期。只要项目基于一定之规,它的整个生命周期都能够轻松搞定,代价是牺牲了灵活性。

在对DSL(Domain Specific Languages)的热情持续高涨之时,通常的想法是设计一套能够解决特定领域问题的语言。在构建这方面,DSL的一个成功案例就是Gradle。

Gradle
Gradle结合了前两者的优点,在此基础之上做了很多改进。它具有Ant的强大和灵活,又有Maven的生命周期管理且易于使用。最终结果就是一个工具在2012年华丽诞生并且很快地获得了广泛关注。例如,Google采用Gradle作为Android OS的默认构建工具。
Gradle不用XML,它使用基于Groovy的专门的DSL,从而使Gradle构建脚本变得比用Ant和Maven写的要简洁清晰。Gradle样板文件的代码很少,这是因为它的DSL被设计用于解决特定的问题:贯穿软件的生命周期,从编译,到静态检查,到测试,直到打包和部署。
它使用Apache Ivy来处理Jar包的依赖。
Gradle的成就可以概括为:约定好,灵活性也高。
代码示例
我们写一段构建脚本来完成从编译、静态检查、单元测试到最终打Jar包的过程。我们分别使用三个框架(Ant,Maven和Gradle)来完成这件事情,比较一下语法。通过比较每一个任务的代码,我们能够对差异有一个更好的理解,并对选择构建工具做出一个周全的决策。
事有先后,如果你自己按照本文来学习样例,需要安装Ant,Ivy,Maven和Gradle,请根据相应工具的安装指导进行操作。你也可以不用自己跑样例,也统统不用安装,代码片段应该足够让你明白这些工具是如何工作的。
代码库 https://github.com/vfarcic/JavaBuildTools包含有Java代码(两个简单的类和测试代码),checkstyle配置文件和Ant,Ivy,Maven以及Gradle的配置文件。
先从Ant带着Ivy开始
Any带着Ivy
Ivy的依赖需要在ivy.xml中指定。我们的例子很简单,只需要依赖JUnit和Hamcrest。

ivy.xml

[html] view plaincopy







现在我们来创建Ant脚本,任务只是编译一个Jar文件。最终文件是下面的build.xml。

build.xml

[html] view plaincopy

<property name="src.dir" value="src"/>  
<property name="build.dir" value="build"/>  
<property name="classes.dir" value="${build.dir}/classes"/>  
<property name="jar.dir" value="${build.dir}/jar"/>  
<property name="lib.dir" value="lib" />  
<path id="lib.path.id">  
    <fileset dir="${lib.dir}" />  
</path>  

<target name="resolve">  
    <ivy:retrieve />  
</target>  

<target name="clean">  
    <delete dir="${build.dir}"/>  
</target>  

<target name="compile" depends="resolve">  
    <mkdir dir="${classes.dir}"/>  
    <javac srcdir="${src.dir}" destdir="${classes.dir}" classpathref="lib.path.id"/>  
</target>  

<target name="jar" depends="compile">  
    <mkdir dir="${jar.dir}"/>  
    <jar destfile="${jar.dir}/${ant.project.name}.jar" basedir="${classes.dir}"/>  
</target>  


首先,我们设置了几个属性,然后是一个接一个的task。我们用Ivy来处理依赖,清理,编译和打包,这是几乎所有的Java项目都会进行的task,配置有很多。
运行Ant task来生成Jar文件,执行下面的命令。
[plain] view plaincopy
ant jar

我们来看Maven如何完成同样的工作。
Maven
pom.xml
[html] view plaincopy

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值