`

比较Maven和Ant

    博客分类:
  • java
 
阅读更多
虽然上一节应该已经让你确信本书的作者没有兴趣挑起 Apache Ant 和 Apache Maven
之间的争执,但是我们认识到许多组织必须在 Apache Ant 和 Apache Maven 之间做一
个选择。本节我们对比一下这两个工具。
Ant 在构建过程方面十分优秀,它是一个基于任务和依赖的构建系统。每个任务包含一
组由 XML 编码的指令。有 copy 任务和 javac 任务,以及 jar 任务。在你使用 Ant
的时候,你为 Ant 提供特定的指令以编译和打包你的输出。看下面的例子,一个简单
的 build.xml 文件:

例 1.1. 一个简单的 Ant build.xml 文件
<project name="my-project" default="dist" basedir=".">
<description>
simple example build file
</description>
<!-- set global properties for this build -->
<property name="src" location="src/main/java"/>
<property name="build" location="target/classes"/>
<property name="dist" location="target"/>
<target name="init">
<!-- Create the time stamp -->
<tstamp/>
<!-- Create the build directory structure used by compile -->
<mkdir dir="org.apache.maven.model.Build@d7e661"/>
</target>
<target name="compile" depends="init"
description="compile the source " >
<!-- Compile the java code from ${src} into org.apache.maven.model.Build@d7e661 <javac srcdir="${src}" destdir="org.apache.maven.model.Build@d7e661"/>
</target>
<target name="dist" depends="compile"
description="generate the distribution" >
<!-- Create the distribution directory -->
<mkdir dir="${dist}/lib"/>
<!-- Put everything in org.apache.maven.model.Build@d7e661 into the MyProject-${<jar jarfile="${dist}/lib/MyProject-${DSTAMP}.jar" basedir="org.apache.maven.model.</target>
<target name="clean"
description="clean up" >
<!-- Delete the org.apache.maven.model.Build@d7e661 and ${dist} directory trees <delete dir="org.apache.maven.model.Build@d7e661"/>
<delete dir="${dist}"/>
</target>
</project>
在这个简单的 Ant 例子中,你能看到,你需要明确的告诉 Ant 你想让它做什么。有
一个包含 javac 任务的编译目标用来将 src/main/java 的源码编译至 target/classes
目录。你必须明确告诉 Ant 你的源码在哪里,结果字节码你想存储在哪里,如何将这

些字节码打包成 JAR 文件。虽然最近有些进展以帮助 Ant 减少程序,但一个开发者对
Ant 的感受是用 XML 编写程序语言。
用 Maven 样例与之前的 Ant 样例做个比较。在 Maven 中,要从 Java 源码创建一个
JAR 文件,你只需要创建一个简单的 pom.xml,将你的源码放在 /usr/local/hudson/
hudson-home/jobs/maven-guide-zh-to-production/workspace/content-zh/src/main/
java ,然后从命令行运行 mvn install。下面的样例 Maven pom.xml 文件能完成和之
前 Ant 样例所做的同样的事情。
例 1.2. 一个简单的 Maven pom.xml
<project>
<modelVersion>4.0.0</modelVersion>
<groupId>org.sonatype.mavenbook</groupId>
<artifactId>my-project</artifactId>
<version>1.0</version>
</project>
这就是你 pom.xml 的全部。从命令行运行 mvn install 会处理资源文件,编译源代
码,运行单元测试,创建一个 JAR ,然后把这个 JAR 安装到本地仓库以为其它项目提
供重用性。不用做任何修改,你可以运行 mvn site ,然后在 target/site 目录找到
一个 index.html 文件,这个文件链接了 JavaDoc 和一些关于源代码的报告。
诚然,这是一个最简单的样例项目。一个只包含源代码并且生成一个 JAR 的项目。一
个遵循 Maven 的约定,不需要任何依赖和定制的项目。如果我们想要定制行为,我们
的 pom.xml 的大小将会增加,在最大的项目中,你能看到一个非常复杂的 Maven POM
的集合,它们包含了大量的插件定制和依赖声明。但是,虽然你项目的 POM 文件变得
增大,它们包含的信息与一个差不多大小的基于 Ant 项目的构建文件的信息是完全不
同的。Maven POM 包含声明:“这是一个 JAR 项目”,“源代码在 src/main/java 目
录”。Ant 构建文件包含显式的指令:“这是一个项目”,“源代码在 src/main/java
”,“针对这个目录运行 javac ”,“把结果放到 target/classes ”,“从……创
建一个 JAR ”,等等。Ant 必须的过程必须是显式的,而 Maven 有一些“内置”的东
西使它知道源代码在哪里,如何处理它们。
该例中 Ant 和 Maven 的区别是:

Apache Ant
Ant 没有正式的约定如一个一般项目的目录结构,你必须明确的告诉 Ant 哪
里去找源代码,哪里放置输出。随着时间的推移,非正式的约定出现了,但是
它们还没有在产品中模式化。

Ant 是程序化的,你必须明确的告诉 Ant 做什么,什么时候做。你必须告诉
它去编译,然后复制,然后压缩。
Ant 没有生命周期,你必须定义目标和目标之间的依赖。你必须手工为每个目
标附上一个任务序列。
Apache Maven
Maven 拥有约定,因为你遵循了约定,它已经知道你的源代码在哪里。它把字
节码放到 target/classes ,然后在 target 生成一个 JAR 文件。
Maven 是声明式的。你需要做的只是创建一个 pom.xml 文件然后将源代码放
到默认的目录。Maven 会帮你处理其它的事情。
Maven 有一个生命周期,当你运行 mvn install 的时候被调用。这条命令告
诉 Maven 执行一系列的有序的步骤,直到到达你指定的生命周期。遍历生命
周期旅途中的一个影响就是,Maven 运行了许多默认的插件目标,这些目标完
成了像编译和创建一个 JAR 文件这样的工作。
Maven 以插件的形式为一些一般的项目任务提供了内置的智能。如果你想要编写运行
单元测试,你需要做的只是编写测试然后放到 /usr/local/hudson/hudson-home/jobs/
maven-guide-zh-to-production/workspace/content-zh/src/test/java ,添加一个对
于 TestNG 或者 JUnit 的测试范围依赖,然后运行 mvn test 。如果你想要部署一个
web 应用而非 JAR ,你需要做的是改变你的项目类型为 war ,然后把你文档根目录置
为 /usr/local/hudson/hudson-home/jobs/maven-guide-zh-to-production/workspace/
content-zh/src/main/webapp 。当然,你可以用 Ant 做这些事情,但是你将需要从零
开始写这些指令。使用 Ant ,你首先需要确定 JUnit JAR 文件应该放在哪里,然后你
需要创建一个包含这个 JUnit JAR 文件的 classpath ,然后告诉 Ant 它应该从哪里
去找测试源代码,编写一个目标来编译测试源代码为字节码,使用 JUnit 来执行单元
测试。
没有诸如 antlibs 和 lvy 等技术的支持(即使有了这些支持技术),Ant 给人感觉是
自定义的程序化构建。项目中一组高效的坚持约定的 Maven POM ,相对于 Ant 的配置
文件,只有很少的 XML 。Maven 的另一个优点是它依靠广泛公用的 Maven 插件。所有
人使用 Maven Surefire 插件来运行单元测试,如果有人添加了一些针对新的测试框
架的支持,你可以仅仅通过在你项目的 POM 中升级某个特定插件的版本来获得新的功
能。
使用 Maven 还是 Ant 的决定不是非此即彼的,Ant 在复杂的构建中还有它的位置。
如果你目前的构建包含一些高度自定义的过程,或者你已经写了一些 Ant 脚本通过一
种明确的方法完成一个明确的过程,而这种过程不适合 Maven 标准,你仍然可以在
Maven 中用这些脚本。作为一个 Maven 的核心插件, Ant 还是可用的。自定义的插件
可以用 Ant 来实现,Maven 项目可以配置成在生命周期中运行 Ant 的脚本。

1.8. 总结
我们刻意的使这篇介绍保持得简短。 我们略述了一些Maven定义的要点,它们合起来是
什么,它是基于什么改进的,同时介绍了其它构建工具。 下一章将深入一个简单的项
目,看 Maven 如何能够通过最小数量的配置来执行典型的任务。
分享到:
评论

相关推荐

    maven-ant-tasks-2.1.3.zip

    通过手动配置和使用 `maven-ant-tasks-2.1.3.jar`,开发者可以在 Ant 构建环境中高效地管理依赖和执行 Maven 目标,提高开发效率。在实际项目中,根据具体的构建需求,合理运用 Maven Ant Tasks,可以大大提升开发和...

    maven-ant-tasks.jar

    还在为找不到jar文件烦心吗,不用了到我空间来有你想要的,持续更新。。。 maven-ant-tasks.jar

    Maven 与 Ant 之比较

    标题“Maven 与 Ant 之比较”表明了本文将探讨两种在Java开发中广泛使用的构建工具——Maven和Ant。它们的主要功能是管理和自动化项目的构建过程,包括编译源代码、运行测试、打包应用以及部署。通过对两者进行对比...

    通向架构师的道路(第二十三天)maven与ant的奇妙整合.docx

    Maven 和 Ant 是两种常见的自动化构建工具,它们都有其独特的优点和缺点。在本文中,我们将探讨如何将 Maven 和 Ant 整合,以充分发挥两者的优势。 一、Maven 介绍 Maven 是一款基于项目对象模型(POM)的自动化...

    maven compare to the ant

    本文将重点比较Maven和Ant两种流行的构建工具,分析它们的特点、优势以及应用场景。 #### Maven与Ant的基本介绍 1. **Apache Ant**: - **定义**:Ant是一款用Java编写的开源构建工具。 - **特点**:基于XML配置...

    maven-ant-tasks-2.1.3-src

    The Mavent Ant Tasks allow several of Maven's artifact handling features to be used from within an Ant build. These include: Dependency management - including transitive dependencies, scope ...

    Maven2.Ant.Junit合集

    《Maven2.Ant.Junit合集》是一个包含多种IT工具和框架的资源包,主要聚焦于Java开发中的构建管理和单元测试。这个合集提供了PDF和CHM两种格式的文档,便于不同用户根据个人喜好进行阅读。以下是这些工具及其重要知识...

    maven-ant-tasks:Apache Maven ant任务的镜像

    总的来说,maven-ant-tasks是连接Maven和Ant的桥梁,它使得开发者可以在保留现有Ant构建脚本的同时,利用Maven的强大功能,提高项目的构建效率和一致性。通过熟练掌握maven-ant-tasks的使用,可以实现更高效、灵活的...

    Maven权威指南 很精典的学习教程,比ANT更好用

    比较Maven和Ant 1.8. 总结 2. 安装和运行Maven 2.1. 验证你的Java安装 2.2. 下载Maven 2.3. 安装Maven 2.3.1. 在Mac OSX上安装Maven 2.3.2. 在Microsoft Windows上安装Maven 2.3.3. 在Linux上安装Maven ...

    maven下通用的ant配置文件

    maven下通用的ant配置文件,只要0积分。只需修改11行末尾的target/自己的工程名即可。

    maven ant thrift0.9.0

    标题 "maven ant thrift0.9.0" 涉及到的是三个关键的软件开发工具:Thrift 0.9.0、Apache Ant 和 Apache Maven。这些工具在Java和其他编程语言的开发环境中广泛使用,特别是在构建和部署分布式系统时。 Thrift ...

    Maven: the complete reference

    #### Maven与Ant的比较 Maven和Ant都是用于构建Java项目的工具,但它们有着根本的不同。Ant更加灵活,允许用户自定义构建过程,适用于复杂的构建场景;而Maven则更加强调标准化和自动化,适用于大规模的项目管理和...

    Maven权威指南

    **1.7 比较Maven和Ant** - **灵活性**:Ant提供更自由的构建过程,适合复杂和特殊的构建需求。 - **易用性**:Maven提供了标准化的构建流程,对新手更加友好。 - **扩展性**:Maven通过插件系统提供了丰富的扩展性...

    apache tomcat,maven,ant下载

    Apache Tomcat、Maven 和 Ant 是Java开发和部署中不可或缺的工具。让我们分别详细了解一下这三个重要组件及其在Java生态系统中的作用。 Apache Tomcat是一个开源的Servlet容器,它实现了Java Servlet和JavaServer ...

Global site tag (gtag.js) - Google Analytics