1.scala和maven如何整合
java
<?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/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>WordCount2</groupId> <artifactId>WordCount2</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>org.scala-lang</groupId> <artifactId>scala-library</artifactId> <version>2.10.4</version> </dependency> <dependency> <groupId>org.scala-lang</groupId> <artifactId>scala-compiler</artifactId> <version>2.10.4</version> </dependency> <dependency> <groupId>org.scala-lang</groupId> <artifactId>scala-reflect</artifactId> <version>2.10.4</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.12</version> </dependency> <dependency> <groupId>org.apache.spark</groupId> <artifactId>spark-core_2.10</artifactId> <version>1.5.2</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.scala-tools</groupId> <artifactId>maven-scala-plugin</artifactId> <version>2.15.2</version> <executions> <execution> <goals> <goal>compile</goal> <goal>testCompile</goal> </goals> </execution> </executions> </plugin> </plugins> </build> </project>
最下面的plugin是用來編譯scala源代碼的,畢竟java與scala是二種不一樣的語言,有各自的sdk和編譯器,因此須要專門的maven插件來處理scala的編譯。
項目的目錄結構,大致跟maven的默認約定同樣,只是src下多了一個scala目錄,以下圖:apache
這樣,java源代碼放在/src/java下,scala源代碼放在/src/scala下,管理起來也比較清爽,上圖中scala下的Hello.scala源代碼以下:maven
1
2
3
4
5
6
7
|
package
yjmyzz
class
Hello {
def
sayHello(x
:
String)
:
Unit
=
{
println(
"hello,"
+ x);
}
}
|
而後java下的HelloWorld.java裏就能夠調用scala的Hello類:ide
1
2
3
4
5
6
7
8
9
|
package
yjmyzz;
public
class
HelloWorld {
public
static
void
main(String[] args){
Hello h =
new
Hello();
h.sayHello(
"scala"
);
}
}
|
2.scala項目maven的編譯打包ui
若是直接運行mvn clean package ,會杯具的發現idea
[ERROR] /Users/jimmy/Work/IdeaProjects/Default/MyScala/src/main/java/yjmyzz/HelloWorld.java:[7,9] cannot find symbol
[ERROR] symbol: class Hello
[ERROR] location: class yjmyzz.HelloWorldspa
緣由是mvn clean package默認只處理java源代碼的編譯、打包,而無論scala,因此編譯時遇到Hello這個由scala語言編寫的class,此時scala還沒編譯生成class,因此找不到相應的調用入口。插件
解決辦法:scala
mvn clean scala:compile compile packagecode
如上,在compile前加入scala:compile,這是maven-scala-plugin插件提供的選項,表示編譯scala,這樣一來,先編譯scala,再編譯java,最後打包,妥妥滴!