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

2017-01-12 04:03:44 济宁新闻网

机器学习新星: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 形成冲击,雷锋网(公众号:雷锋网)将拭目以待。

viajaxenter

济宁IT新闻

济宁新闻网版权与免责声明:

一、凡本站中注明“来源:济宁新闻网”的所有文字、图片和音视频,版权均属济宁新闻网所有,转载时必须注明“来源:济宁新闻网”,并附上原文链接。

二、凡来源非济宁新闻网或北京晚报的新闻(作品)只代表本网传播该消息,并不代表赞同其观点。

如因作品内容、版权和其它问题需要同本网联系的,请在见网后30日内进行,联系邮箱:452584743@qq.com

takefoto