最近做的项目中一直是在使用maven,但是要知道最早出来的构建工具是Ant,现在Ant依然有好多人再用,于是自己就抽出来时间,学习了一下Ant的基本的使用。这样也能跟好的理解Maven提供的新特性。
首先说一下他们各自的作用:
Ant的作用:是一种基于Java的build工具
- 可以用ant编译java类,生成class文件
- ant可以自定义标签、配置文件,用于构建。
- ant可以把相关层构建成jar包 。
- ant把整个项目生成web包,并发布到Tomcat
Ant的优点:
- 跨平台性:Ant是纯Java语言编写的,因此具有很好的跨平台性。
- 操作简单:Ant是由一个内置任务和可选任务组成的。Ant运行时需要一个XML文件(构建文件)。
- Ant通过调用target树,就可以执行各种task:每个task实现了特定接口对象。由于Ant构建文件时XML格式的文件,所以很容易维护和书写,而且结构很清晰。
- Ant可以集成到开发环境中:由于Ant的跨平台性和操作简单的特点,它很容易集成到一些开发环境中去。
Maven的作用: 除了以程序构建能力为特色之外,还提供高级项目管理工具。
Maven除了具备Ant的功能外,还增加了以下主要的功能:
- 使用Project Object Model来对软件项目管理;
- 内置了更多的隐式规则,使得构建文件更加简单;
- 内置依赖管理和Repository来实现依赖的管理和统一存储;
- 内置了软件构建的生命周期;
Maven的优点:
- 拥有约定,知道你的代码在哪里,放到哪里去
- 拥有一个生命周期,例如执行 mvn install
就可以自动执行编译,测试,打包等构建过程 - 只需要定义一个pom.xml,然后把源码放到默认的目录,Maven帮你处理其他事情
- 拥有依赖管理,仓库管理
整体的比较:
Ant
将提供了很多可以重用的task,例如 copy, move, delete
以及junit
单元测试Maven
则提供了很多可以重用的过程。
我们可以把 Maven
看成是一个"build container"这个容器可以让我们重用从一系列的项目中抽像出来的build过程。
使用过Ant的朋友都会有这样的体会吧。Ant提供的task级别描述,我们可以通过想写shell一样一个Java项目的build过程来进行描述。我们可以写好一个build.xml
文件,来解决我们在Java程序运行编译过程中需要解决的classpath,以及相关参数的配置问题,只有是项目中的主要结构以及依赖的库不变,我们很少去修改build.xml。但是如果我们要开发一个新的项目即使原有项目的build.xml写的即使再好,其能够复用得模块还是比较少的。特别是对项目的结构进行修改后,想不修改build.xml都很困难。这是因为Ant
所提供的可重用的task粒度太小,虽然灵活性很强,但是我们需要纠缠很多细节的东西。
正如你所在使用Servlet
容器时,并没有告诉它如何去解包WAR文件,在你使用Maven
时,你也不需要告诉Maven
如何build你的项目。Maven提供了一套抽象层用来分离项目的build
逻辑。许多人一开始就被Maven所提供的依赖管理(可以通过XML来描述项目所依赖的库的关系)打动,但是使用Maven的主要好处还是它能为提供一个标准的开发构架用来对多个项目进行管理。
依赖管理只是这个标准开发构架所提供的一个副产品。
如果想让Maven实现某个build过程,例如compile,
test, install,我们可以通过写plugin的方式,很容易就实现build过程的复用。Maven可以为我们提供一个很舒适的build环境,我们不需要通过build.xml定义繁琐的build过程,
只需要告诉这些build过程的plugin,我现在的文件依赖的那些第三方库,我需要实现什么样的build功能,就足够了。那些繁琐的路径配置信息,以及复杂的第三方库下载设置,你通通不用考虑,
Maven 以及它的plugin都帮你实现了。
版权声明:本文为博主原创文章,未经博主允许不得转载。