Scala是一种运行于JVM之上的新型语言。JRuby, Jython, Groovy等也可以将其他语言的一些特点带进Java的生态圈。但就个人体会,Scala和这些编程语言相比,如同Symbian之于Android或IOS。虽然大家都是一个圈子里面的,但完全不在同一个时代。加之Play Framework的助力,Scala的路会越走越宽。对于企业开发,Scala最大的障碍不在对之前Java产品的支持,而在程序员的数量上。Scala的切入点很好,因为它是强类型的语言,在运行的性能上远超出JRuby, Jython, Groovy,执行效率与Native的Java程序几无差别。在对Java的互操作方面体现很好,这就保证了企业可在使用Scala的开发中保证了之前Java软件产品的投资不会丢失。而它带入的函数式编程,对多线程编程的良好支持,为开发大量并发应用体现出优势。(这也是Play Framework的亮点)
回到现实,Scala短期内还无迹象被业界大规模采用。但如果打算将Scala带进企业开发,最好的出发点可能是自动化测试和支持软件开发的工具。对于这两方面,大多数企业的态度是,知道长期来看它的好处,但不愿在眼下去投资。如果要想做些事情,程序员不得不牺牲自己的业余时间。而Scala用于此再合适不过。所以下面我将Scala项目的开发搭建搭建做了一个总结。学语言,学以致用,用它去做一些正经的事情。
1. 安装、配置需要的软件
Scala: http://www.scala-lang.org/downloads
Scala IDE: http://scala-ide.org/
Scala-sbt: http://www.scala-sbt.org/release/docs/Getting-Started/Setup.html
因为sbt会使用ivy作为库管理工具。ivy默认把library repository建在user home下面。Unix/Linux/Mac OS都还好说,如果就一个分区(或一个逻辑分区),无所谓发在哪个位置啦。如果操作系统是Windows,有分了C: D: E: 等若干分区,还是不要放在默认的%USERPROFILE%下面,C盘会随着开发的项目越来越多,大量的空间被开发库所占用。定制library local repository的位置的方法是:
编辑文件sbt启动脚本: [sbt安装目录]\sbt.bat,设置Java启动参数:-Dsbt.ivy.home=E:/dev/ivy/
@REM SBT launcher script
@REM
@REM Envioronment:
@REM JAVA_HOME - location of a JDK home dir (mandatory)
@REM SBT_OPTS - JVM options (optional)
@setlocal
@echo off
set SBT_HOME=%~dp0
set ERROR_CODE=0
rem We use the value of the JAVACMD environment variable if defined
set _JAVACMD=%JAVACMD%
if "%_JAVACMD%"=="" (
if not "%JAVA_HOME%"=="" (
if exist "%JAVA_HOME%\bin\java.exe" set "_JAVACMD=%JAVA_HOME%\bin\java.exe"
)
)
if "%_JAVACMD%"=="" set _JAVACMD=java
rem We use the value of the JAVA_OPTS environment variable if defined
set _JAVA_OPTS=%JAVA_OPTS%
if "%_JAVA_OPTS%"=="" set _JAVA_OPTS=-Xmx512M -XX:MaxPermSize=256m -XX:ReservedCodeCacheSize=128m -Dsbt.log.format=true Dsbt
:run
"%_JAVACMD%" %_JAVA_OPTS% %SBT_OPTS% -cp "%SBT_HOME%jansi.jar;%SBT_HOME%sbt-launch.jar;%SBT_HOME%classes" SbtJansiLaunch %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal
exit /B %ERROR_CODE%
用sbt创建,运行,测试和发布项目都很方便,但这还不够,软件开发是要写代码的。而务实的开发者都会用现代的IDE去写代码。用写字板,vi或其他文本编辑做开发,更多的是体现一种编程文化的象征意义,正经干活没必要放着更先进的好东西不用。好,这方面咱们就不解释了。说正事。安装sbteclipse插件 https://github.com/typesafehub/sbteclipse , 可以在sbt console里面生成eclipse scala project。更为有用的事,sbteclipse在生成项目时会根据build.sbt里面定义的库依赖,生成一个.classpath文件。也就是说把Eclipse Scala项目的classpath,设置好了。如果以后的开发中有使用新的第三方库,安装如下次序,可以更新classpath的配置
1). 在build.sbt里面定义库依赖
2). 在sbt console里面执行update命令,下载相应的库到local library repository
3). 在sbt console里面执行eclipse命令,更新classpath设置
2. 用sbt创建项目
这里用一个例子来说明:
f:\tmp\test>dir
Volume in drive F is file
Volume Serial Number is A646-F0A7
Directory of f:\tmp\test
02/19/2013 02:09 PM <DIR> .
02/19/2013 02:09 PM <DIR> ..
02/19/2013 11:04 AM 269 build.sbt
02/19/2013 02:08 PM <DIR> target
1 File(s) 269 bytes
3 Dir(s) 29,323,710,464 bytes free
f:\tmp\test>type build.sbt
name := "Project Plan"
version := "1.0"
scalaVersion := "2.9.2"
libraryDependencies ++= Seq(
"org.mongodb" %% "casbah" % "2.5.0",
"net.sourceforge" % "mpxj" % "4.3.0"
)
f:\tmp\test>sbt
[info] Loading global plugins from C:\Users\gzhang\.sbt\plugins
[info] Set current project to Project Plan (in build file:/F:/tmp/test/)
> eclipse
[info] About to create Eclipse project files for your project(s).
[info] Updating {file:/F:/tmp/test/}default-c4a35f...
[info] Resolving org.scala-lang#scala-library;2.9.2 ...
[info] Resolving org.mongodb#casbah_2.9.2;2.5.0 ...
[info] Resolving org.mongodb#casbah-commons_2.9.2;2.5.0 ...
[info] Resolving com.github.nscala-time#nscala-time_2.9.2;0.2.0 ...
[info] Resolving joda-time#joda-time;2.1 ...
[info] Resolving org.joda#joda-convert;1.2 ...
[info] Resolving org.specs2#specs2_2.9.2;1.12.2 ...
[info] Resolving org.specs2#specs2-scalaz-core_2.9.2;6.0.1 ...
[info] Resolving org.slf4j#slf4j-api;1.6.0 ...
[info] Resolving org.mongodb#mongo-java-driver;2.10.1 ...
[info] Resolving org.mongodb#casbah-core_2.9.2;2.5.0 ...
[info] Resolving org.mongodb#casbah-query_2.9.2;2.5.0 ...
[info] Resolving org.mongodb#casbah-gridfs_2.9.2;2.5.0 ...
[info] Resolving net.sourceforge#mpxj;4.3.0 ...
[info] Resolving org.apache.poi#poi;3.7 ...
[info] Resolving junit#junit;3.8.1 ...
[info] Done updating.
[info] Successfully created Eclipse project files for project(s):
[info] Project Plan
> exit
f:\tmp\test>tree
Folder PATH listing for volume file
Volume serial number is A646-F0A7
F:.
├─project
│ └─target
│ └─config-classes
├─src
│ ├─main
│ │ ├─java
│ │ └─scala
│ └─test
│ ├─java
│ └─scala
└─target
├─scala-2.9.2
│ └─cache
│ └─update
└─streams
└─$global
├─ivy-configuration
│ └─$global
├─ivy-sbt
│ └─$global
├─project-descriptors
│ └─$global
└─update
└─$global
其中,
定义build.sbt文件,请参照sbt的文档: http://www.scala-sbt.org/release/docs/index.html。 特别说明的是,当添加一个依赖库的时候,通过Maven Central Repository Search来查找很便捷。比如,项目需要使用Mongo DB的driver
在Maven Central Repository里面查找”mongodb“:
点击所需库的版本号到Artifact Details页面:
展开Scala SBT,将里面的Dependency Information拷贝粘贴到build.sbt文件里面,然后在sbt console里面运用update,eclipse。下载库,配置项目的classpath就自动完成了。
http://www.tuicool.com/articles/AJnIvq
相关推荐
使用SBT开发Scala,SBT是scala项目和Java项目集成的有利工具,使用SBT管理Scala和Java项目集成,非常方便!
sbt是一个用于构建Scala和Java项目的构建工具,要求Java 1.6或者更新版本。
scala 编译工具 sbt 安装包。 Little or no configuration required for simple projects Scala-based build definition that can use the full flexibility of Scala code Accurate incremental recompilation ...
基于windows10和jdk1.8的scala+sbt+idea的开发环境的详细安装教程,希望对您有用,后期还会更新,请关注,一起进步,谢谢!
[Packt Publishing] SBT 入门教程 (Scala 实现) (英文版) [Packt Publishing] Getting Started with SBT for Scala (E-Book) ☆ 图书概要:☆ Equip yourself with a high-productivity work environment using ...
SBT 是 Scala 的构建工具,全称是 Simple Build Tool, 类似 Maven 或 Gradle。 SBT 的采用Scala编程语言本身编写配置文件
Intellj idea 2017.1.1 sbt 插件,用于离线安装Scala sbt,安装后可以创建sbt 项目
数字IC、verilog、scala、chisel
IntelliJ IDEA使用SBT构建一个AKKA Scala程序
SBT ivy2 scala构建工具jar包 scala 构建工具 sbt
专门介绍SBT构建scala应用的新书,对学习scala很有帮助
SBT ivy2 scala构建工具boot包
scala-native.g8, Giter8模板,用于使用 Scala 本机的最小项目 这是一个用于 Scala 原生的最小 Giter8 模板sbt new scala-native/scala-native.g8许可证由EPFL编写的2017. 在规律范围内,作者将所有版权和相邻的权限...
sbt-coveralls, Sbt插件将 Scala 代码覆盖到 coveralls coveralls SBT插件将 Scala 代码覆盖到 https://coveralls.io,并与 Travis CI集成。 这个插件使用 scoverage插件来生成代码覆盖率度量。有关使用这里插件的...
使用Scala+IntelliJ IDEA+Sbt搭建开发环境
包含 Scala-2.12.8 和 sbt-1.2.8 安装包,这两个安装包都是从官网下载下来的,亲测可用
官方提供的sbt文档,涵盖sbt的安装,使用,问题的解决等,内容丰富,是学习使用sbt打包scala的必备文档。
sbt-with-docker 使用docker构建sbt-scala imege
使用Eclipse编写Spark应用程序(scala+sbt) 112 使用Eclipse编写Spark应用程序(scala)(建议) 121 使用Eclipse编写Spark应用程序(java+maven) 123 使用Eclipse编写Spark应用程序(java) 128 Storm安装和...
wget了一上午才下载下来scala-sbt的api,有需要参考的可下载。 version:0.13.12 2016.11.13