欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
從零開(kāi)始用好 Maven

來(lái)源:lmportNew - 唐尤華


1. Maven簡(jiǎn)介


Apache Maven 是一個(gè)軟件項目管理工具?;陧椖繉ο竽P停≒OM)的理念,通過(guò)一段核心描述信息來(lái)管理項目構建、報告和文檔信息。


Maven 是一個(gè)意第緒語(yǔ)(猶太人使用的國際語(yǔ))單詞,意思是知識的累加器。它最開(kāi)始是被用來(lái)簡(jiǎn)化 Jakarta Turbine 項目的構建過(guò)程。在 Jakarta Turbine 項目中有幾個(gè)不同的項目,雖然它們的Ant構建文件差異很小,但是 jar 包都在 CVS 上。于是想要找到一個(gè)標準而又簡(jiǎn)單的項目構建方法,既可以清晰地定義出這個(gè)項目由什么構成并發(fā)布項目信息,又能在不同項目間共享Jar包。


現在,任何一個(gè)基于Java的項目都能使用Maven來(lái)構建和管理,使 Java 開(kāi)發(fā)人員的日常工作變得更輕松,讓Java項目更容易被理解。


2. Maven使用


2.1 安裝


必備條件: 已安裝JDK


注意事項: Maven 3.3 及更高版本要求 JDK1.7 或者更高版本


2.2 Windows


下載解壓縮


  • 打開(kāi)下載頁(yè)面:http://maven.apache.org/download.cgi

  • 選擇最新的版本,或者到這里 https://archive.apache.org/dist/maven/maven-3/ 找到你中意的版本

  • 下載 apache-maven-{版本號}-bin.zip

  • 找到合適的目錄:最好無(wú)空格和中文,解壓,內容如下


bin\

boot\

conf\

lib\

README.txt

NOTICE

LICENSE


配置環(huán)境變量


  • 計算機 > 屬性 > 高級系統設置 > 環(huán)境變量 > 系統變量

  • 新建 M2_HOME 變量,內容為 {解壓路徑}\apache-maven-{版本號}

  • 編輯 Path 變量,在內容結尾加上 ;%M2_HOME%\bin;


2.3 Linux


包管理器安裝


$ sudo apt install maven


下載安裝


  • 下載 apache-maven-{版本號}-bin.tar.gz

  • 配置環(huán)境變量 export PATH=/opt/apache-maven-{版本號}/bin:$PATH


2.4 驗證


Windows 打開(kāi) Cmd,Linux 運行 Shell,看到下面信息表示安裝成功。


$ mvn -version

Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-11-11T00:41:47 08:00)

Maven home: D:\software\java\apache-maven-3.3.9

Java version: 1.8.0_191, vendor: Oracle Corporation

Java home: c:\Program Files\java\jdk1.8.0_191\jre

Default locale: zh_CN, platform encoding: GBK

OS name: 'windows 7', version: '6.1', arch: 'amd64', family: 'dos'


2.5 設置Maven


Maven通過(guò) settings.xml 進(jìn)行配置


完整的參數說(shuō)明可查看 


http://maven.apache.org/ref/3.6.0/maven-settings/settings.html


2.5.1 自定義倉庫位置(可選)


Maven 下載的 jar 包默認存儲到 ${user.home}/.m2/repository


編輯 {安裝路徑}\config\settings.xml,在下面增加一行填入自定義位置:


  <!-- localRepository

   | The path to the local repository maven will use to store artifacts.

   |

   | Default: ${user.home}/.m2/repository

  <localRepository>/path/to/local/repo</localRepository>

  -->

<localRepository>{自定義位置}\repository</localRepository>


Linux 查看安裝路徑


$ ls -lsa /usr/share/maven

...

 0 lrwxrwxrwx   1 root root    10 12月 10  2015 conf -> /etc/maven

 

$ ls -lsa /etc/maven

 4 drwxr-xr-x   2 root root  4096 11月 27 11:45 logging

 4 -rw-r--r--   1 root root   222 11月 19  2015 m2.conf

12 -rw-r--r--   1 root root 10216 11月 19  2015 settings.xml

 4 -rw-r--r--   1 root root  3649 11月 19  2015 toolchains.xml


2.5.2 設置國內鏡像(可選)


Maven 默認從中央倉庫 central 下載


改為國內鏡像速度更快


編輯 {安裝路徑}\config\settings.xml,在 <mirrors></mirrors> 標簽里加入新的鏡像:


<mirrors>

    <mirror>

      <id>alimaven</id>

      <mirrorOf>central</mirrorOf>

      <name>aliyun maven</name>

      <url>https://maven.aliyun.com/repository/central</url>

    </mirror>

</mirrors>


3. 使用


3.1 快速上手


3.1.1 新建示例項目


命令行不是必須的,但這個(gè)過(guò)程能有助于理解在 IDE 中的操作。


命令行新建項目


Windows 打開(kāi) Cmd,Linux 運行 Shell,執行下面指令。


mvn archetype:generate -DgroupId=org.tyh.mvn.quickstart -DartifactId=mvn-quickstart -DarchetypeArtifactId=maven-archetype-quickstart -DarchetypeVersion=1.3 -DinteractiveMode=false


執行成功可以看到下面字樣:


[INFO] BUILD SUCCESS


POM.xml 包含了命令中的信息


<groupId>org.tyh.mvn.quickstart</groupId>

<artifactId>mvn-quickstart</artifactId>

<version>1.0-SNAPSHOT</version>

<name>mvn-quickstart</name>


目錄結構


quickstart 項目的結構如下:


  • 項目源碼:src/main/java

  • Web 項目源碼:src/main/webapp

  • 測試源碼:src/test/java

  • Maven 項目結構(Project Object Model POM):pom.xml


注意: 配置文件,如 log4j.properties 需要新建 src\main\resources 目錄。這樣編譯時(shí)會(huì )打包到生成的 jar 中。


mvn-quickstart

│  pom.xml

│  

└─src

    ├─main

    │  └─java

    │      └─org

    │          └─tyh

    │              └─mvn

    │                  └─quickstart

    │                          App.java

    │                          

    └─test

        └─java

            └─org

                └─tyh

                    └─mvn

                        └─quickstart

                                AppTest.java


提示: 生成目錄結構,Windows 在 Cmd 中輸入 tree /f,Linux 安裝 tree 程序后可直接輸入 tree。


有關(guān)目錄結構完整介紹可以查看


http://maven.apache.org/guides/introduction/introduction-to-the-standard-directory-layout.html


3.1.2 構建項目


Windows 打開(kāi) Cmd,Linux 運行 Shell,執行下面指令。


mvn package


執行成功可以看到下面字樣:


[INFO] BUILD SUCCESS


查看生成結果,在項目中新增了 target 目錄,里面主要關(guān)注以下文件:


  • class 文件:target\classes\org\tyh\mvn\quickstart\App.class

  • test-classes 文件:target\test-classes\org\tyh\mvn\quickstart\AppTest.class

  • jar 文件:target\mvn-quickstart-1.0-SNAPSHOT.jar


mvn-quickstart

│  pom.xml

│ 

└─target

    │  mvn-quickstart-1.0-SNAPSHOT.jar

    │  

    ├─classes

    │  └─org

    │      └─tyh

    │          └─mvn

    │              └─quickstart

    │                      App.class

    │                      

    ├─generated-sources

    │  └─annotations

    ├─generated-test-sources

    │  └─test-annotations

    ├─maven-archiver

    │      pom.properties

    │      

    ├─maven-status

    │  └─maven-compiler-plugin

    │      ├─compile

    │      │  └─default-compile

    │      │          createdFiles.lst

    │      │          inputFiles.lst

    │      │          

    │      └─testCompile

    │          └─default-testCompile

    │                  createdFiles.lst

    │                  inputFiles.lst

    │                  

    ├─surefire-reports

    │      org.tyh.mvn.quickstart.AppTest.txt

    │      TEST-org.tyh.mvn.quickstart.AppTest.xml

    │      

    └─test-classes

        └─org

            └─tyh

                └─mvn

                    └─quickstart

                            AppTest.class


3.1.3 運行


Windows 打開(kāi) Cmd,Linux 運行 Shell,執行下面指令。


java -cp target/mvn-quickstart-1.0-SNAPSHOT.jar org.tyh.mvn.quickstart.App

Hello World!


執行測試:


mvn test


執行成功可以看到下面的結果:


[INFO] -------------------------------------------------------

[INFO]  T E S T S

[INFO] -------------------------------------------------------

[INFO] Running org.tyh.mvn.quickstart.AppTest

[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.133 s - in org.tyh.mvn.quickstart.AppTest

[INFO]

[INFO] Results:

[INFO]

[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0


3.2 新增依賴(lài)


3.2.1 搜索Maven


為項目添加一個(gè)依賴(lài),比如 Apache Commons Lang 和 Slf4j 日志。


搜索


搜索時(shí)可采用高級搜索,g:{groupId} a:{artifactId}。例如 g:log4j a:log4j 就會(huì )列出 log4j 的最新版本。


  • Maven central 倉庫:https://search.maven.org/

  • Aliyun 鏡像倉庫:http://maven.aliyun.com/mvn/search

  • 其他搜索倉庫

  • https://repository.apache.org

  • https://mvnrepository.com


注意: 類(lèi)似 slf4j 這樣依賴(lài)其他實(shí)現的包,需要查看官方文檔,確認需要配合使用的 jar 包。否則會(huì )出 現編譯通過(guò),運行報錯 的情況。


3.2.2 加入依賴(lài)項


<dependencies>

    <dependency>

      <groupId>junit</groupId>

      <artifactId>junit</artifactId>

      <version>4.11</version>

      <scope>test</scope>

    </dependency>

 

    <!--Slf4j(slf4j-log4j12)-->

    <!--添加后,會(huì )同時(shí)引入 log4j 和 slf4j-api-->

    <dependency>

      <groupId>org.slf4j</groupId>

      <artifactId>slf4j-log4j12</artifactId>

      <version>1.8.0-beta2</version>

    </dependency>

 

    <!--Apache Commons Lang (commons-lang3)-->

    <dependency>

      <groupId>org.apache.commons</groupId>

      <artifactId>commons-lang3</artifactId>

      <version>3.8.1</version>

    </dependency>

</dependencies>


3.2.3 驗證


修改 App 類(lèi),加入 Log 和 測試代碼:


package org.tyh.mvn.quickstart;

 

import org.apache.commons.lang3.ArrayUtils;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

 

/**

 * ArrayUtils Demo

 *

 */

public class App 

{

    public static void main( String[] args )

    {

        Logger logger = LoggerFactory.getLogger(App.class);

 

        float[] farr = {1.1f, 1.2f, 1.3f};

        logger.info(ArrayUtils.toString(farr));

 

        farr = ArrayUtils.removeElements(farr, 1.1f);

        logger.info(ArrayUtils.toString(farr));

    }

}


執行程序之前,要找到依賴(lài)的 jar 文件所在的目錄。默認是在 {用戶(hù)主目錄}/.m2/ 目錄 下,利用 dependency:copy 插件 可以拷貝到 target\dependency 目錄:


mvn dependency:copy-dependencies


查看結果:


├─dependency

│      commons-lang3-3.8.1.jar

│      hamcrest-core-1.3.jar

│      junit-4.11.jar

│      log4j-1.2.17.jar

│      slf4j-api-1.8.0-beta2.jar

│      slf4j-log4j12-1.8.0-beta2.jar


在命令行運行時(shí),用 -cp 加入依賴(lài)的 jar 所在目錄:


java -cp .;dependency/*;mvn-quickstart-1.0-SNAPSHOT.jar org.tyh.mvn.quickstart.App


注意: 編譯前需要加入 log4j.properties 到 src\main\resources 目錄。下面是一個(gè) Windows 下的 log4j.properties。


# Root logger option

log4j.rootLogger=INFO, file, stdout

 

# Direct log messages to a log file

log4j.appender.file=org.apache.log4j.RollingFileAppender

log4j.appender.file.File=C:\\temp\\logging.log

log4j.appender.file.MaxFileSize=10MB

log4j.appender.file.MaxBackupIndex=10

log4j.appender.file.layout=org.apache.log4j.PatternLayout

log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n

 

# Direct log messages to stdout

log4j.appender.stdout=org.apache.log4j.ConsoleAppender

log4j.appender.stdout.Target=System.out

log4j.appender.stdout.layout=org.apache.log4j.PatternLayout

log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n


3.3 IDE中使用


3.3.1 Eclipse


新建項目


1. 新建 Maven 項目


  • File > New > Project

  • 選擇 Maven Project (目錄報錯及解決辦法*)

  • (可選)項目類(lèi)型 maven-archetype-simple 或其他類(lèi)型

  • 輸入 Group Id, Artifact Id, Name,Finish


2. 添加依賴(lài)


  • pom.xml 右鍵菜單 > Maven > Add Dependency

  • 在輸入框中輸入,比如 slf4j 會(huì )自動(dòng)列出匹配結果,OK

  • 加入新的依賴(lài)保存文件,會(huì )在 Maven Dependencies 中列出 jar 及路徑,并添加到項目的 classpath 中


3. 編碼


  • 編寫(xiě) Java 代碼,調試


4. 構建


  • 項目 右鍵菜單 > Run As > Maven build

  • 第一次運行會(huì )提示輸入 Maven build 的目標:Goal 里填寫(xiě) package 進(jìn)行構建 (支持的常用命令可以在這里找到 Maven in 5 Minutes:Maven Phases)


導入項目


  • File > Import

  • 選擇 Maven > Existing Maven Project

  • 選擇項目 pom.xml 目錄,Projects: 下面勾選 target

  • 點(diǎn)擊完成


3.3.2 Idea


1. 新建 Maven 項目


  • File > New > Project

  • 選擇 Maven

  • (可選)項目類(lèi)型 maven-archetype-simple 或其他類(lèi)型

  • 輸入 Group Id, Artifact Id

  • 輸入項目名稱(chēng),Finish


2. 添加依賴(lài)


  • pom.xml 手動(dòng)添加依賴(lài)信息

  • 加入新的依賴(lài)保存文件,會(huì )在 External Libraries 中列出 jar 及路徑,并添加到項目的 classpath 中


3. 編碼


  • 編寫(xiě) Java 代碼,調試


4. 構建


  • pom.xml 右鍵菜單 > Build module’module name’

  • Maven build 會(huì )提示警告:Warning:java: 源值1.5已過(guò)時(shí), 將在未來(lái)所有發(fā)行版中刪除:可加入配置項解決


4. 常見(jiàn)問(wèn)題與辦法


4.1 如何設置編譯支持的 JDK 版本?


全局指定


下面的腳本指定編譯版本兼容 JDK 1.7


<project>

  ...

  <properties>

    <maven.compiler.source>1.7</maven.compiler.source>

    <maven.compiler.target>1.7</maven.compiler.target>

  </properties>

  ...

</project>


指定插件


在不改變全局兼容性的情況下,可以在插件中指定。例如,下面的腳本指定了 maven-compiler-plugin 編譯的版本兼容 JDK 1.7。


<project>

  ...

  <build>

  ...

    <plugins>

      <plugin>

        <groupId>org.apache.maven.plugins</groupId>

        <artifactId>maven-compiler-plugin</artifactId>

        <version>3.3</version>

        <configuration>

          <source>1.7</source>

          <target>1.7</target>

        </configuration>

      </plugin>

    </plugins>

  ...

  </build>

  ...

</project>


4.2 如何指定自己的目錄結構?


可以通過(guò)設置 <build> 節點(diǎn)下 <sourceDirectory>, <resources> 參數指定。


4.3 在 pom 文件中配置了依賴(lài),編譯時(shí)還會(huì )報錯。


下載的 jar 文件可能有問(wèn)題。


  • 檢查 maven 倉庫地址,在搜索條件中檢查 groupId 和 artifactId 是否正確。

  • mvn clean 清理文件。

  • mvn package 重新編譯。


4.4 [WARNING] File encoding has not been set, using platform encoding UTF-8, i.e. build is platform dependent!


POM 文件中沒(méi)有指定編譯時(shí)編碼格式,可加入下面屬性指定為 UTF-8。


<properties>

    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>

</properties>


類(lèi)似的問(wèn)題: [WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources, i.e. build is platform dependent!


4.5 Invalid project description. … overlaps the workspace …


Eclipse 新建 Maven 項目時(shí),可能會(huì )報告此錯誤。解決辦法兩種:


  1. 選擇 workspace 以外的目錄作為項目目錄;

  2. 新建 Java Project,然后轉為 Maven 項目:右鍵菜單 Config -> Convert to Maven Project


4.6 Warning:java: 源值1.5已過(guò)時(shí), 將在未來(lái)所有發(fā)行版中刪除


Idea 在 Maven Build 時(shí)發(fā)出警告,在 pom.xml 中加入以下內容:


<build>

    <sourceDirectory>src</sourceDirectory>

    <plugins>

        <plugin>

            <artifactId>maven-compiler-plugin</artifactId>

            <version>3.8.0</version>

            <configuration>

                <source>1.8</source>

                <target>1.8</target>

            </configuration>

        </plugin>

    </plugins>

</build>


【關(guān)于投稿】


如果大家有原創(chuàng )好文投稿,請直接給公號發(fā)送留言。


① 留言格式:
【投稿】 《 文章標題》  文章鏈接

② 示例:
【投稿】《不要自稱(chēng)是程序員,我十多年的 IT 職場(chǎng)總結》:http://blog.jobbole.com/94148/

③ 最后請附上您的個(gè)人簡(jiǎn)介哈~


本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
maven常用命令介紹
maven2 (二) SCM
Maven學(xué)習筆記2——向repository上傳artifact
[翻譯]Maven五分鐘入門(mén)
關(guān)于Maven
Maven入門(mén)指南(一) | 并發(fā)編程網(wǎng)
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久