java:ant:build.xml简析

一、Ant是什么?
    Ant(蚂蚁)是一个基于Java的自动化和XML格式的脚本引擎。这样说可能大家不是很形象,不是很容易理解,我们看看它在什么情况下比较适用吧:
    比如:当一个项目的代码量很大时候,我们每次添加代码都要重新编译整个项目,然后运行查看结果是否符合要求,如果是web项目的话,每一次的运行都要经历重新编译、打成war包、然后发布、这样测试起来都变的很是复杂而且重复,因此Ant就我们提供了一个很好的类似于C语言中用到的Make脚本的buid.xml文件来帮助这些工作的批量完成。Ant本身可以自动化调用程序完成项目的编译,打包,测试等。一些列重复而繁琐的事情。现在对Ant有一个大概的了解了吧!我们接着看。

二、Ant的基本使用方法
    要很好的使用Ant 我们就必须了解Ant的任务和内部标签,我做一下简单的介绍吧:
    任务1:usage 打印本脚本的帮助信息(缺省)
    任务2:clean <-- init 清空初始化环境
    任务3:javadoc <-- build <-- init 生成Javadoc
    任务4:jar <-- build <-- init 生成JAR
    任务5:all <-- jar + javadoc <-- build <-- init

    从上面的罗列中不难发现:多个任务之间往往又包含了一定了依赖关系:比如把整个应用打包任务(jar)的这个依赖于编译任务(build),而编译任务又依赖于整个环境初始化任务(init)等。
     然而在很多项目的ant脚本中的命名基本上都是一致的,比如:编译一般叫build或者compile;打包一般叫jar或war;生成文档一般命名为javadoc或javadocs;执行全部任务all。在每个任务的中,ANT会根据配置调用一些外部应用并配以相应参数执行。虽然ANT可调用的外部应用种类非常丰富,但其实最常用的就2,3个:比如javac javadoc jar等。

缺省任务:usage 打印帮助文档,告诉有那些任务选项:可用的有build, jar, javadoc和clean。

初始化环境变量:init

所有任务都基于一些基本环境变量的设置初始化完成,是后续其他任务的基础,在环境初始化过程中,有2点比较可以方便设置:

1、除了使用却缺省的property设置了JAVA源路径和输出路径外,引用了一个外部的build.properties文件中的设置:

<property file="${basedir}
/build.properties" />
这样大部分简单配置用户只要会看懂build.properties就可以了,毕竟XML比起key value的属性文件还是要可读性差一些。用build.properties也可以方便其他用户从编译的细节中解放出来。

2、CLASSPATH设置:使用了其中的:

 <path id="classpath">
        <pathelement path="${jsdk_jar}"/>
        <fileset dir="${lib.dir}">
           <include name="**/*.jar"/>
        </fileset>
    </path>



则相当于设置了:

CLASSPATH=/path/to/resin/lib/jsdk23.jar;
           /path/to/project/lib/*.jar;
文件复制:prepare-src

创建临时SRC存放目录和输出目录。

<target name="prepare-src"
  depends="init">
    <!-- create directories -->
    <mkdir dir="${build.src}"/>
    <mkdir dir="${build.dest}"/>
    
    <!-- copy src files -->
    <copy todir="${build.src}">
      <fileset dir="${src.dir}"/>
    </copy>
  </target>


 
编译任务:build

编译时的CLASSPATH环境通过一下方式找到引用一个path对象

 <classpath refid="classpath"/>



打包任务:jar

对应用打包生成项目所写名的.jar文件

<target name="jar" depends="build">
    <jar jarfile="${lib.dir}/${name}.jar"
         basedir="${build.dest}"
         includes="**"/>
  </target>


 
生成JAVADOC文档任务: javadoc

<target name="javadoc" depends="build">
    <mkdir dir="${build.javadocs}"/>
    <javadoc packagenames="${packages}"
             sourcepath="${build.src}"
             destdir="${build.javadocs}"
             author="true"
             version="true"
             use="true"
             splitindex="true"
             windowtitle="${Name} API"
             doctitle="${Name}">
      <classpath refid="classpath"/>
    </javadoc>
  </target>


 
清空临时编译文件:clean

<target name="clean" depends="init">
    <delete dir="${build.src}"/>
    <delete dir="${build.dest}/org"/>
    <delete dir="${build.dest}/com"/>
    <delete>
      <fileset dir="${build.dest}" 
	  includes="**/*.class"/>
    </delete>
  </target>

 

 

 

你可能感兴趣的:(java,xml,ant,脚本)