游客

机器学习新星:Scala优于Java的五大理由!

游客 2017-01-11 18:40:47    200947 次浏览

机器学习新星:Scala优于Java的五大理由!

Java 在程序猿江湖的霸主地位已经很多年没有受到挑战了。

作为一门主流编程语言,在所有领域的普及率、职业选择、业界倾向榜单中,Java 即使不在榜首,也位于前列。即便是 Python 为王的机器学习领域,Java 的普及程度也稳居第二、三位,仅有 R 语言可与之相比。Java 能有如此巨大的成功,跟它的灵活多功能,以及处理复杂任务的能力是分不开的。但有没有比 Java 更好的选择呢?

就雷锋网所知,在资深程序猿眼中,能替代 Java、并且能做得比它更好的只有 Scala。这篇文章并不是对 Scala 平白无故的吹捧文,而是基于:

  • 大家知道 Scala 在业内的口碑不错;

  • 作为一个后起之秀,它解决了 Java 普遍存在的许多问题;

  • 另一方面, Scala 的性能比 Java 更加强大;

  • 上期盘点中,我们还发现,在机器学习领域,2014 年后 Scala 在美国的招聘需求出现井喷,是发展最快的机器学习开发语言(详见 Python、R、Java、 C 等:从业界反馈看机器学习语言趋势)。

但是,作为一门新兴语言,国内对于 Scala 的认识较少。下面,来看看国外移动游戏开发商 Nimblechapps 的创始人兼 CEO Keval Padia,总结的 Scala 优于 Java 的五大理由:

机器学习新星:Scala优于Java的五大理由!

Nimblechapps 的 logo

1. 更快地投放市场

如果你是一个业余开发者,不存在项目市场、成本方面的考虑,对这一条 Scala 的优点或许你并不感冒。但对于所有领工资的开发者,必须要在规定时间内把产品投放市场。这是一个没有争议的、Scala 优于 Java 的领域。对于 Scala,OO(面向对象)模式在执行代码时的限制并不存在。在这一模式之外,还能为算法加入函数式编程。这使得原本两个世界——面向对象语言和函数式语言的优点能被结合起来。这产生的结果是具有非凡表达力的细节和简洁明了的代码——经常只有几行。更少的代码行数在所有方面都提高了速度,不管是测试还是开发。

2. 避免死锁(deadlock)

作为一名码农,你也许经常在编程中遇到出现死锁的情况。最可怕的空指针异常(null pointer exception)以及其它变种,就是很好的例子

Scala 能提供一个直截了当的解决方案吗?不能。但它提供了一些能事先避免死锁的、十分有效的选择。当你开始用 Scala 写代码,你一定会注意到空指针异常出现的次数比 Java 大幅减少。

3. 更好的写代码输出

首先,函数式编程能帮助你的 app 提高稳定性,并且带走很多本无意产生的副产品。当你从可变数据结构( mutable data structures)转移至所谓的函数式模式,你会保证更高的安全性、稳定性。

第二点,没有标点的代码会变成更强。Scala 的代码支持混合能力和多种继承(inheritanCES)这会帮助你找出代码中的漏洞、缺陷。更干净、强大的代码帮助开发者提升终端应用的安全和表现。

4. 第三方 API 储备

所有开发者都需要为 app 加入功能。如今,这有两种方式:白手起家从头写代码,或者从第三方应用中移植过来。现在程序架构师都需要走过这个关键路口——决定到底是自己开发整个功能,还是直接拿来一个插件。

但其实还有第三种方式:Scala 提供了一个更强大的解决方案:它搭载了多种宝贵的内置功能。由于这一点,你对自己的应用有远远更好的控制力。Scala 简单、直接的代码也能够提升载入速度。

5. 异步处理

不同于 Java,Scala 为传递异步行为(asynchronous behavior)而设计。未来就绪(future readiness)在 Java 的缺失,导致了一系列限制了应用功能的妥协。但就像其他网络开发框架一样,Scala 中的异步行为提供了非常舒服、自然的代码。

机器学习新星:Scala优于Java的五大理由!

看了这五大优点,你是否已经准备拿 Scala 试试手了呢?但雷锋网要提醒读者们,不要期望太高。比如说,它在国内的大环境并不理想,使用 Scala 的人太少,工作机会比国外少得多。对于个体而言,它也并不适合每个人。大牛 David Pollak 曾经表示:“对于 50% 的 Java 开发者,学习 Scala 的难度高于它带来的便捷。”在早年的博客中,他反复强调 Scala 是一个面向聪明人的语言,是一个给热爱写代码的人充分发挥自己才能的平台。

换句话说,Scala 难以在大众开发者群体之间推广。但近两三年来,全世界已经目睹美国掀起的 Scala 风潮。虽然作为游戏公司的 CEO,Keval PadiaScala 只是从手机端 app 开发的角度看待 Scala;但在机器学习领域,Scala 也已获得相当多自认天赋不凡的极客作为拥趸。

至于在将来,Scala 能否在国内高端开发者社区对 Java 形成冲击,雷锋网(公众号:雷锋网)将拭目以待。

via jaxenter

内容加载中