`
Eastsun
  • 浏览: 308848 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

为什么选择Scala?

阅读更多
原文地址: http://www.infoq.com/cn/news/2008/01/why-scala

在回答“为什么选择Scala?”这个问题之前,我们首先需要回答“什么是Scala?”。从Scala网站上,可以找到如下概述:

引用
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#一样的编译模型(独立编译,动态装载类),允许访问成千上万的高质量类库。

对于某些开发者来说,这些刺激已足以引诱他们脱离Java进入Scala世界。但对另外一些开发者来说,它们并没有为Java世界里当前正在演绎的日复一日的编程活动提供更多好处。

在一篇名为“Scala:集Ruby和Java之所长”的博文中,Ian讲述了或许不应在Java和Scala之间做出选择,相反,相对于选择其它语言如Ruby,选择使用Java和Scala的混合物是的另一种选择:

许多开发者热爱Ruby,不过他们不能从中获取足够的东西。它可能是最具侵略性的语言之一,因为Java才是第一个到场的。人们总是引证Ruby的灵活而可扩展的语法、闭包等特性,以及其代码如何简明和具有表现力。

例如,你可以用一个简单语法创建一个Map(Ruby称之为“hashes”,尽管hashtable只是map一种可能的实现方式),如:

numberMap = {"one" => 1, "two" => 2, "three" => 3}
Java与之对等的语句显得颇为冗长:

Map<String, Integer> numberMap = new HashMap<String, Integer>(); numberMap.put("one", 1); numberMap.put("two", 2); numberMap.put("three", 3);
那么Scala怎么样呢?让我们看看Scala中map的例子:

var numberMap = Map("one" -> 1, "two" -> 2, "three" -> 3)
你会注意到它看上去非常类似等价的Ruby代码,但是这儿有一些重要区别。特别是,就像Java,Scala编译器知道numberMap使用String作为键,Integer作为值。与Java不同的是,你无需告知,它本身就能领会这一点!这称为“类型推理(type inference)”。

这意味着如果你试图给numberMap增加一个新的键值对,但是要使用Integer作为键,String作为值,Scala将在你试图编译它时立刻报错(或者你的IDE将立刻警告你)。使用Ruby,只有当你运行你的软件并试图从该Map中找回该键和值时,得到的分别是Integer和String而不是所期望的String和Integer,这时才会导致报错。

过分强调编译时类型检查节省多少多少时间是困难的,但它消除了所有类在执行时将会产生的bug。Scala给你带来了这一好处,而且代码并不繁琐。

为更进一步在一个小例子中展现代码量的缩减,Ted Neward研究了开发同一个类,用Java、C#、Virual Basic、Ruby和Scala的区别。请参考其博文Scala pt 2:简短。

Ian继续指出:

Scala还有一连串其它好的Ruby特性(Java所缺乏的),包括闭包,以及非常适合“领域特定语言”的可塑性语法。它拥有所有这些特性,而且结合了静态类型好处。
David MacIver在其博文说正经的,为什么选择Scala?中分享了他对于面向对象编程、面向模块编程、静态类型、函数编程以及该语言中他所喜欢的未言明特性的观点。他补充道:


Scala离完美还差得远。它有一些语法缺陷,一些由Java带来的问题,一个有适度问题的编译器以及一堆你记不住的琐碎特性和边界情况(edge case)。然而,我发现这些问题除了烦你之外并不真正产生什么后果。如果只是想坐下来书写好的代码,该语言的核心是强大的和非常有用的。
为了提供一个均衡的观点,David在其博文中接着探讨了为什么不选Scala,文中他阐述了一些边界情况(edge case)。作为总结,David有如下评论:


总而言之,我发现这些只是增加了一些烦心事。它仍是我最喜欢的JVM语言,但是你的看法将取决于你怎样搁置那些对你来说可能是更重要的需要优先考虑的事情。
为了展现Scala是一门不断成熟的语言,Programming in Scala一书很快将会出版。如果等不及,Artima网站上有该书PDF格式的预印版。


做出自己的决定,或想学习更多关于Scala内容,请关注他们的网站。

分享到:
评论
3 楼 ray_linn 2008-05-13  
这个Ted Neward的水平是很次的,他的C#代码压根就是驼臭狗屎
2 楼 Eastsun 2008-04-20  
貌似有个基于Scala的Web框架Lift.
引用

什么因素使得Scala成为构建一个Web框架的伟大环境?

句法。性能。稳定性。一个仅当你需要的时候才出现的优秀的类型系统。闭包。模式匹配。内建的XML语言支持(XML literals)。Actor[译注:Scala的基本并发构造]。很难说什么是决定性因素。
lift与Rails以及Seaside或者其他Java框架例如Structs或者Spring的区别是什么?

像Rails一样容易而简明。
像Seaside和Wicket一样安全而正式。

类型安全但不像Struts一样冗长。

支持允许多人合作的“实时”应用。

所以,你可以飞快地构建巨强大的应用(就像Rails),但是你不必把所有的状态一股脑地扔进一个关系数据库中。状态是“活的”而不是冻干的,这使得写从前端访问数据库表的应用非常地不同以往。

你可以描述一下你在生产环境中部署lift的经验么?你看到的性能如何?

我对lift应用做了许多基准性能测试。lift的渲染管道简明扼要,而且lift在标准的web容器中运行。这意味着你可以得到与良好开发的J2EE应用相同的性能。对于数据库无关的页面,lift的渲染时间通常低于1秒。对于需要访问数据库的页面,页面渲染时间与数据库访问相关。在一个Amazon EC2实例上(1.7Ghz Intel处理器,2GB内存),我可以支撑每秒500+的页面访问,其中50%的页面要访问数据库,而且MySQL实例与Web应用运行在相同的服务器上。
你如何看待lift与现存的Java应用配合工作,或者在混合语言环境(例如JRuby)中工作?

lift与现存的Java代码配合工作的非常好。lift的RabbitMQ和XMPP支持是基于Java库的。Scala可以100%无缝的调用Java代码。Scala可以100%无缝的实现Java接口,继承Java类。它就是可以工作。至少有一个lift项目,其中lfit和Spring在同一个WAR文件中共存。我的第一个Scala应用是一个Servlet容器。"它就是可以工作"让我松了一大口气。
1 楼 floating 2008-04-20  
不知道Scala有没有大规模应用的例子?我最近开始考虑在公司里大规模引入groovy,碰巧看到你这篇文章,觉得单纯从语言特性上讲Scala似乎比groovy更好些。不知道你在这方面有什么体会?在项目中使用Scala的成本高不高?

相关推荐

    Scala in Action.pdf

    - **第1章:为什么选择Scala?** - **内容要点**:介绍Scala语言的优势及其与其他语言的对比。 - **目标读者**:对Scala感兴趣但尚未入门的新手。 - **第2章:快速上手** - **内容要点**:包括Scala安装指南、...

    scala in action

    首先,在“为什么选择Scala?”这一章节中,作者对比Scala与其他编程语言的特点,指出Scala支持的高级特性,例如类型推断、模式匹配和不可变数据结构等。对于面向对象程序员来说,Scala提供了更高级的OOP特性,如类...

    Scala.in.Action

    1. **为什么选择Scala?** - **语言特性**:Scala融合了面向对象和函数式编程的优点,提供了一种更简洁、更具表达力的编程方式。 - **代码效率**:相较于Java等传统面向对象语言,Scala能够用更少的代码实现相同...

    Scala如果你在银行工作你懂得

    1. **并发性**:Scala的Actor模型为构建并发系统提供了原生支持。Actors是轻量级的线程,它们通过消息传递进行通信,确保了线程安全,减少了锁的使用,提高了系统的并行性能。 2. **类型系统**:Scala的静态类型...

    whyscala:为什么我喜欢 Scala?

    "为什么我喜欢 Scala?" 这个标题揭示了作者对 Scala 的热爱,并可能探讨了 Scala 的诸多优点。 首先,Scala 的类型系统是其独特之处。它采用了静态类型,确保了代码的健壮性,同时它的类型推断机制减少了冗余的类型...

    scala习题精选100道附带解析

    ### Scala习题精选知识点解析 #### 1. 关于与Scala进行交互的基本方式REPL的说明 - **知识点概述**:REPL(Read-Eval-Print Loop)是一种交互式的编程环境,用户可以在其中输入代码,系统立即执行并显示结果。在...

    Scala考试题1

    - 柯里化是将接受多个参数的函数转换为一系列只接受一个参数的函数的过程。 13. **模式匹配与 Java switch-case 的不同**: - Scala 的模式匹配更强大,支持值匹配、类型匹配、提取器对象等,而 Java 的 switch-...

    scala-fmi-2019:索非亚大学教授的Scala函数式编程课程材料

    使用Scala进行高级功能编程讲课[] 函数式编程的简要历史为什么选择Scala? Scala作为SCalable语言。 样例代码安装和工具你好,世界测验[] Scala原理基本类型和基本类型。 文字定义val , var , def 。 类型和类型...

    scala-2.12.10.zip

    这个"scala-2.12.10.zip"文件是Scala编程语言的特定版本——2.12.10,专为Windows操作系统设计的安装包。Scala 2.12.x系列是该语言的一个稳定版本,它提供了许多新特性和改进,旨在提高开发人员的效率和代码的可维护...

    scala + mybatis 数据库查询

    - Scala的静态类型系统和强大的表达能力使其成为构建复杂应用程序的良好选择,而MyBatis以其灵活性和易用性在Java世界中占有一席之地。通过使用Scala的Java互操作性,我们可以无缝地在Scala中使用MyBatis。 - 集成...

    scala实战高清讲解

    - Scala的独特之处在于它允许开发者根据需求自由选择面向对象或函数式编程风格,或者两者的结合。 10. **案例研究** - Spark:Apache Spark是一个基于Scala构建的大数据处理框架,展示了Scala在大数据领域的应用...

    windows版scala-2.11.12.zip

    解压后,你会得到一个名为"scala-2.11.12"的文件夹,其中包含了Scala编译器(scalac)、解释器(scala)和其他相关工具。为了在命令行中使用Scala,你需要将 Scala 的 bin 目录添加到系统的PATH环境变量中。这样,...

    scala-2.12.3|2.11.11.msi网盘下载链接

    在选择Scala版本时,主要考虑以下几点: 1. **兼容性**:如果你的应用程序需要与特定版本的Java或其他Scala应用程序兼容,那么应选择与之相匹配的Scala版本。 2. **社区支持**:新版本通常会修复旧版本中的问题并...

    scala-2.12.14.zip&scala-2.12.11.tgz Linux版本压缩包.rar

    1. **类型推断**:开发者无需为每条语句都指定类型,编译器可以根据上下文自动推断。 2. **模式匹配**:允许通过模式来解构复杂数据结构,简化代码并提高可读性。 3. **函数式编程**:支持高阶函数、柯里化、尾递归...

    Scala下载安装教程

    在右键“src”选项中,选择“New”-&gt;“scala class”,并将 kind 选项选择为“object”。然后,输入代码,点击三角符号运行即可。 后续学习 Scala 是一个强大且灵活的编程语言,它提供了广泛的应用领域。本教程...

    scala-2.12.6.tgz

    Scala是一种强大的多范式编程语言,它融合了面向对象和函数式...总的来说,Scala-2.12.6.tgz是学习和开发用Scala语言的必备工具,它为开发者提供了高效、富有表现力的编程环境,特别适合构建复杂、高性能的应用系统。

    官网scala-2.11.8版本安装包

    1. 下载Spark的源码或者预编译版本,通常选择对应Scala版本的版本,例如`spark-3.x.y-bin-hadoop2.x.y.tgz`。 2. 解压下载的文件,同样将其路径添加到系统路径中。 3. 如果需要在本地运行Spark,可以直接通过`bin/...

Global site tag (gtag.js) - Google Analytics