一位Twitter工程师的Scala探秘之旅
创始人
2024-04-22 09:41:40
0

一位Twitter工程师的Scala探秘之旅 

【51CTO精选译文】本文的这个故事讲述一个对编程语言有种近乎于宗教狂热的Twitter工程师是如何投入Scala的怀抱的。一开始大量使用Ruby做为开发语言的Twitter曾遭遇过严重的性能问题,于是Twitter在寻找可扩展性强的替代语言的时候,找到了Scala。

一位Twitter工程师的Scala探秘之旅 

大家好,我是al3x,一位编程语言的瘾君子,哦不,是狂热份子。我在工作中使用过Java,JavaScript,C,PHP,Perl,Ruby以及Python。出于兴趣和爱,接触过x86 Assembly,Erlang,Lua,Objective-C,Lisp家族,Haskell,以及C++。

一位Twitter工程师的Scala探秘之旅 

我为Twitter工作。Twitter一直以来都大量使用Ruby。Ruby很好,但不是都好。Ruby VM低下的性能,monkeypatching(51CTO编者注:猴子补丁,也称鸭子击,指对动态语言运行时进行扩展或修改,而无须更改源代码的一个方法),以及文化上的问题,在大型项目中的使用还是充满疑问。我们要建造新的服务,感觉不想继续用Ruby开发了。

对于Ruby的不满,基本可以总结如下:

1)Ruby不太合适开发长时间运行(Long-Live)的服务器端程序,但JVM很合适,因为Java有10年的经验教训和优化,Scala是运行在JVM上的,所以天生就有了这个优点;

2)  Ruby没有很好的线程(Thread)支持,Ruby多线程会限制在一个CPU上(新的Ruby应该会改善这点吧)且Ruby VM的垃圾收集支持也没有Java先进,就造成每个Ruby进程长时间运行后使用的内存月来越大;

3)  为什么不是JRuby? JRuby缺乏使用广泛的Rem支持(很多优秀的Ruby包都需要C扩展,它们并没有移植到Java),而且性能也不太理想,比MRI(C实现的Ruby VM)要慢

系统语言的白马王子 

我心目中的系统语言白马王子应该是:
◆快速
◆函数式
◆表达能力
◆静态类型
◆并发
◆优美
◆轻量

我们最终想要一个JVM语言,而不是Java 

我们列出的名单:
C
C++
Python
Erlang
Java
JVM上的动态语言

结果没一个满意的。它们都有自己的问题。我们最终想要一个不是Java的JVM语言。

后来,我们听说了Scala 

后来,我们听说了Scala。在JVM上几乎没有哪个语言的执行速度赶得上它,而Scala lift-off看起来令人感到信心十足。

#p#

Scala的特性

类型推断 

不再糟糕的类型推断。静态类型一直是天使和恶魔的共存。在Scala中,在你真正使用它之前,你可以忽略对象的类型。

不变性 

不变性:你可以在最开始用面向对象的方法编程,然后当你需要它的好处时,就可以迁移到用不变状态(immutable state)。实现并发和异步就靠它了。这个功能需要在决策时更加深思熟虑,不过是值得的。

第一类函数 

第一类函数:我们是“类”的追随者。这是个有了就无法失去的功能:你不仅可以定义函数和调用它们,还可以把函数写成没有名字的文本:literal并把它们像值:value那样传递。一切都是表达式,一切都有值。

Scala的特征 

特征:是个奇特的东西,因为继承的未必是你想要的。一个类可以按照需要整合许多特征,这与接口相似,但它们还可包含行为,这又与类相似。同样,与类和接口类似,特征可以引入新方法。

模式匹配与case类 

模式匹配与case类:其实每个程序员天天都在进行模式匹配。Scala不过是令这个过程更简单了。

XML的处理大大的简化 

XML的处理大大的简化了。再怎么说XML技术还在广泛的使用中,使用Scala来处理XML文件是相当不错的选择:有点那么些JavaScript+JSON的意思。

Actors:处理并发 

Actors:处理并发的一个好方法。Scala提供的这个叫做Actor的并行模型通过它的收件箱来发送和接收非同步信息,而不是共享数据。这种方式被称为:shared nothing 模型。一旦你不再顾虑共享数据的问题,也就不必再为代码同步和死锁问题而头痛。

一位Twitter工程师的Scala探秘之旅 

还有上面这些其他的特性,这里就不细说了。51CTO的编辑在此推荐大家去Scala编程语言专题中进行进一步的学习。

范例

最后,给大家看看我们在Twitter中用Scala编写的代码。

一位Twitter工程师的Scala探秘之旅 

函数的使用:无论是array,类型系统,值还是Singleton的语法,都和Ruby一样简便。

一位Twitter工程师的Scala探秘之旅 

Package,import,traits,currying,更多的类型系统。

当然了,Scala也有不好的地方,比如社区太小,而且也偏复杂。不过总的来说,Scala绝对是一门值得学习的语言。

原文:Why Scala?

【相关阅读】

  1. Ruby高手点评Scala编程语言十大绝招
  2. Scala取代Java?可能吗?热议仍持续不断
  3. Groovy创始人:Java面临终结 Scala将取而代之
  4. Scala如何改变了我的编程风格:从命令式到函数式
  5. Java程序员,你为什么要关注Scala

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...