有人問Scala語言是做什麽的,也有人問scala語言會取代Java的嗎,下麵是這些問題的答案。
-
Scala到底是什麽?在目前眾多的JVM語言當中,Scala無疑是最引人注意的語言之一。
-
Scala是一個靜態語言,更適合大型工程項目,Scala直接編譯成Java字節碼,性能接近Java。Scala是一個多範式的語言,你可以混合使用函數式和麵向對象編程,混合使用可變類和不變類,混合使用Actor和傳統的Java並發庫。
-
一個 Twitter 的開發人員說過,Scala 將會成為現代 Web2.0 的發起語言。LinkedIn 也用這種語言。同樣許多其他大的公司如 Sony Picture, EDF, SAP 也開始使用這種語言。為什麽Scala發展這麽迅猛,可以獲得如此熱烈的社區支持。 Scala不是Java的殺手,它無法取代Java的地位,也突破不了JVM的限製、Java實現不了的功能它也實現不了。我們可以將Scala形象的理解成有大量語法糖的Java。
-
Scala 語言的特性有許多,例如高階函數和對象、抽象類型綁定,actor 使得函數在 Scala 中能是一個子類成為可能,Scala 中的設計模式使得麵向對象和函數編程無縫結合。Akka 是一個用 Scala 編寫的庫,用於簡化編寫容錯的、高可伸縮性的 Java 和 Scala 的 Actor 模型應用。它已經成功運用在電信行業。Spark 是一種可擴展的數據分析平台,它整合了內存計算的基元,因此,相對於 Hadoop 的集群存儲方法,它在性能方麵更具優勢。Spark 是在 Scala 語言中實現的,並且利用了該語言,為數據處理提供了獨一無二的環境。
-
Scala 編譯器可以生成字節碼,直接運行在使用JVM上。該語言(它實際上代表了可擴展語言)被定義為可直接集成到語言中的簡單擴展。
scala作為一門靜態語言,它的主要特性有哪些?
- Scala是麵向對象的 Scala是一個純麵向對象語言,在某種意義上來講所有數值都是對象。對象的類型和行為是由class和trait來描述的。Class的抽象可由子類化和一種靈活的基於mixin的組合機製(它可作為多重繼承的簡單替代方案)來擴展。
- Scala是函數式的 Scala還是一個函數式語言,在某種意義上來講所有函數都是數值。Scala為定義匿名函數提供了一種輕量級的語法,它支持高階(higher-order)函數、允 許函數嵌套、支持局部套用(currying)。Scala的case類及其內置支持的模式匹配模型代數類型在許多函數式編程語言中都被使用。
- Scala是靜態類型的 Scala配備了一套富有表現力的類型係統,該抽象概念以一種安全的和一致的方式被使用。
- Scala是可擴展的 Scala的設計承認了實踐事實,領域特定應用開發通常需要領域特定語言擴展。Scala提供了一個獨特的語言組合機製,這可以更加容易地以類庫的形式增加新的語言結構: 任何方式可以被用作中綴(infix)或後綴(postfix)操作符閉包按照所期望的類型(目標類型)自動地被構造 兩者結合使用可方便地定義新語句,無需擴展語法,也無需使用類似宏的元編程工具。
-
Scala可與Java和.NET進行互操作 Scala設計時就考慮了與流行編程環境良好交互,如Java 2運行時環境(JRE)和 .NET框架(CLR)。特別是與主流麵向對象語言,如Java和C#盡量無縫交互。Scala有像Java和C#一樣的編譯模型(獨立編譯,動態裝載類),允許訪問成千上萬的高質量類庫。
-
在並發性方麵 與 Scala 在 .NET 領域中的姐妹語言 F# 相似,Scala 是針對 “並發性問題” 的解決方案之一,讓開發人員能夠更加輕鬆地專注於問題的實質,而不用考慮並發編程的低級細節。Actor 編程模式讓高度並行應用程序的開發更加簡單。Scala把Erlang風格的基於actor的並發帶進了JVM。我們可以利用Scala的actor模型在JVM上設計具伸縮性的並發應用程序,以自動獲得多核心處理器帶來的優勢,而不必依照複雜的Java線程模型來編寫程序。Scala 為並發性提供了兩種級別的支持,這與其他與 Java 相關的主題極為類似:
- 首先對底層庫的完全訪問(比如說 java.util.concurrent)以及對 “傳統” Java 並發性語義的支持(比如說監控程序和wait()/notifyAll())。
- 其次這些基本機製上麵有一個抽象層。Scala 提供了在穩定的高性能平台(Java 虛擬機)上生成的能力同時也是一門敏捷性語言。這一類型的語言也有其他的選擇,例如 Jython, JRuby, Groovy 和 Clojure, 但是這些都是運行在 JVM 上的動態類型語言。Open Class 的效果讓大家會覺得Scala是動態語言,但它是選擇隱式轉換來實現的,這也正好證明了Scala是靜態語言。隱式轉換(Implicit conversion)使 Scala 具有類型安全性,正如擴展方法(extension method)之於 C#,開放類(open class)之於 ruby。即:向未曾定義的類型添加方法(如字符串、列表、整數)。這是使得 Scala 符合 DSL(特定領域語言)模型的特性之一。
-
Scala結合了麵向對象和函數編程的優勢,函數編程的一個好處就是你能夠像運用一個數據那樣運用函數,可以用來定義真正高層級的庫,或者去定義新的領域特殊語言(DSL)。
將Java與Scala對比
Scala能調用絕大部分的Java,而Java調用Scala獨有的東西會比較難。Java 擁有非常強的概念規範,因此任何一個 Java 程序之間具有非常多的相似之處,並且這樣能夠方便的進行程序員交替。但是 Scala 並沒有這樣的統一性,因為這是一門很有表現力的語言。 正所謂,金無足赤,人無完人。Scala對二進製不兼容,語法也越來越複雜,不能突破Bytecode的限製、編譯速度有所緩慢。當它被廣泛用於單元測試、開發工具、Socket開發、以及麵對多核挑戰的並發應用。
總結
總而言之,Scala是一種函數式麵向對象語言,它融匯了許多前所未有的特性,而同時又運行於JVM之上。正如JRuby 創建者之一Charles Nutter 所宣稱的那樣Scala就是 Java 王位的合法繼承人。隨著開發者對Scala的興趣日增,以及越來越多的工具支持,無疑Scala語言將成為廣大軟件工程師手上一件必不可少的工具。