學習Scala一段時間的感想
背負了太多Java平台兼容的包袱,為了大量利用Java平台的強大功能,在設計方面處處考慮兩者的共通性。如語法方面:為了兼容JavaBean規範,通過@BeanProperty註解來實現getter和setter,顯得古怪,也現實上增加了語法層面的複雜度 - 優點是缺點,缺點是優點......
以上這點,我估計Groovy、Clojure,也有類似的情況吧?基於Java平台,在享受Java強大支撐的同時,必然也要受限於Java平台,這點我不是很喜歡,如果說做Java EE開發,舊有的知識已經很熟練的情況下,學習Scala的意義必然大大降低了,那麼,剩下來吸引我的語法糖,其獨特之處到底在哪兒?實際上,函數式的影子,在Ruby上已經展現地很好了...... 而於性能,估計要不同場景不同分析,在需要充分考慮性能的場景下(不是每時每刻都需要著重考慮性能的,只有在少數情況下,性能問題才會浮現),Scala具備一定場景應用優勢,就是其招牌式的並發能力,進一步講,我認為是方便並發編程的能力,因為它在這方面封裝地很好,便於使用,但千萬別搞錯了,絕不是並發能力,因為,Scala跳不出Java平台的掌控。 另一方面,說是Scala進軍了.Net平台?但我查了下,好像許久未更新了?退一步而言,就算是在.Net平台落地生根、開花結果,也只是把上面一句話變變而已:「基於.Net平台,在享受.Net強大支撐的同時,必然也要受限於.Net平台」。 據此,我已深信不疑,Scala絕對取代不了Java。通過這種植入式(如JSR-223規範)的實現,永遠都不可能取代Java,再好(至少從目前來看)也是綠葉配紅花。即使是在語言層面,除非官方原生直接支持或吸取借鑒,否則也不可能取代。但我們應該看到,光從語法角度看(因為我是語法糖控),Scala很「現代」,Java已「老舊」,Java的後續版本,是不是也會借鑒一些「時髦點的東西」呢?我覺得這是肯定的。 很遺憾,不管你喜不喜歡Java,它還是會擺在哪兒。但Scala給了你多一種選擇,你可以選擇它,一行搞掂getter/setter,或者像這樣: "Hello".foldLeft(List[BigInt]())((b,a)=> a::b).reverse.reduce(_*_) 而不用寫羅羅嗦嗦的Java語句。但自己心裡一定要明白,你喜歡的東西並不能取代Java,你也不應該否認Java,雖然你可以罵Java、討厭Java。 如果你第一次接觸函數式語法,恰好又是通過Scala,你會喜歡上Scala;同樣道理,如果你是通過Ruby第一次接觸函數式語法,估計你深深喜歡上的就是Ruby了。無論如何,你接觸第二門類似語法語言的時候,你的熱情必然不太可能燃燒起來 - 所以,如果你想擴展視野,你選一門差不多的語言來學就好了。 回到Java上來說,立志於Java平台開發的,還是應該首先掌握Java語言本身,走穩了,再學飛。 基於興趣來看待Scala比較現實些 - 有興趣就學,沒興趣就算了。我需要Scala嗎?
推薦閱讀:
※基於Scala的產品開發實踐
※Stack monads in Scala
※kotlin和scala兩種語言的對比?
※寫尾遞歸函數有什麼規律或技巧嗎?