您好,登錄后才能下訂單哦!
綜述
本文演示了用Maven編譯Java項目
需要
創建項目
本例主要為了展示Maven,所以Java的項目力求簡單。
創建項目結構 選
擇一個項目目錄,在 *nix系統上使用下面語句
mkdir -p src/main/java/hello
window下使用命令
mkdir src\main\java\hello
創建如下結構:
└── src └── main └── java └── hello
在src/main/java/hello目錄下創建Java文件HelloWorld.java和 Greeter.java
src/main/java/hello/HelloWorld.java
package hello; public class HelloWorld { public static void main(String[] args) { Greeter greeter = new Greeter(); System.out.println(greeter.sayHello()); } }
src/main/java/hello/Greeter.java
package hello; public class Greeter { public String sayHello() { return "Hello world!"; } }
現在項目完成,可以用Maven編譯了。有關Maven的安裝,可以參考Apache Maven 3.1.0 安裝、部署、使用
定義簡單的Maven編譯
首先,在項目的根目錄下創建一個Maven項目定義文件pom.xml,該文件主要是說明項目的名稱、版本和依賴庫
pom.xml
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.springframework</groupId> <artifactId>gs-maven</artifactId> <packaging>jar</packaging> <version>0.1.0</version> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>2.1</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>hello.HelloWorld</mainClass> </transformer> </transformers> </configuration> </execution> </executions> </plugin> </plugins> </build> </project>
除了<packaging> 元素可選外,其他的元素是構成pom.xml 文件的最基本的元素了。它包括以下幾個項目的配置:
編譯Java代碼
運行下面語句編譯
mvn compile
編譯完成的.class文件將會出現在target/classes目錄下.如下圖
運行項目:
mvn exec:java -Dexec.mainClass="hello.HelloWorld"
輸出如下:
如果不想直接運行.class文件,可以將其打包:
mvn package
打包完成后,會在target目錄下生成一個JAR文件,文件名由<artifactId> 和 <version>組成。比如本例,將會根據pom.xml生成gs-maven-0.1.0.jar
如果你想安裝您的項目的JAR文件到本地Maven倉庫,那么你應該調用下面語句:
mvn installmvn install
此時,你的項目代碼將會經過編譯、測試、打包并拷貝到本地依賴庫,提供給其他項目引用。
以上例子源碼的地址https://github.com/waylau/maven-demo中的demo1
說到項目依賴,下面說下聲明依賴
聲明依賴
上面的例子比較簡單,沒有用到其他庫。但是真實的項目可能會引用(依賴)到很多其他庫。
下面例子,依賴了Joda Time的庫。
修改src/main/java/hello/HelloWorld.java
package hello; import org.joda.time.LocalTime; public class HelloWorld { public static void main(String[] args) { LocalTime currentTime = new LocalTime(); System.out.println("The current local time is: " + currentTime); Greeter greeter = new Greeter(); System.out.println(greeter.sayHello()); } }
現在運行mvn compile將會報錯,因為沒有聲明依賴。在 <project> 節點下插入如下:
<dependencies> <dependency> <groupId>joda-time</groupId> <artifactId>joda-time</artifactId> <version>2.2</version> </dependency> </dependencies>
這段內容就聲明了項目的依賴。每個依賴節點<dependency>都由三個子節點組成:
在POM 4中,<dependency> 中還引入了<scope> ,它主要管理依賴的部署。目前<scope> 可以使用5個值:
現在你運行mvn compile或者mvn package,Maven會自動下載相關依賴。
完整的pom.xml
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>org.springframework</groupId> <artifactId>gs-maven</artifactId> <packaging>jar</packaging> <version>0.1.0</version> <!-- tag::joda[] --> <dependencies> <dependency> <groupId>joda-time</groupId> <artifactId>joda-time</artifactId> <version>2.2</version> </dependency> </dependencies> <!-- end::joda[] --> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>2.1</version> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>hello.HelloWorld</mainClass> </transformer> </transformers> </configuration> </execution> </executions> </plugin> </plugins> </build> </project>
運行項目:
mvn exec:java -Dexec.mainClass="hello.HelloWorld"
輸出如下:
以上例子源碼的地址https://github.com/waylau/maven-demo中的demo2
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。