我在Google写过Go(自己的业余时间),也在LinkedIn写过Scala。两者都是具有一流的并发特性的现代语言。

下面的回答是基于我编写大规模的软件的经验得出。

Go是一种开发模式严格固定,并且以最小代码量编译成机器代码的语言。

Scala是一种拥有多种特性并运行在JVM上的,复杂的、学术性的、功能性的、面向对象的沙箱语言。

对于绝大多数开发者的任何一个项目,我每次更愿意选择Go而不是Scala的一个原因是:简单。

第 1 段(可获 1.15 积分)

在我开始回答问题之前,我要进行一些基本的观察:

  • 一般来说,代码越少越容易理解;然而,有一点是代码非常密集,以至于很难读懂。
  • 代码读起来要比写得多。
  • 代码的寿命比我们想要的要长。
  • 测试或维护一段代码的人常常不是原作者。
  • 在规模上,读取/写入/维护/测试代码的开发人员的技能水平将会是“非专家”意义上的正常分布。

编写代码是一种通信行为,不仅是作者和编译器(或运行时)之间的通信,而且也是作者与未知技能水平的未来读者之间的交流。

语言的复杂性

Java 8语言规范是780页的PDF。
http://docs.oracle.com/javase/sp...

Scala语言规范是一个191页的PDF。
http://www.scala-lang.org/docu/f...

Go语言规范是一个网页,打印为51页的PDF。
http://golang.org/ref/spec

定义一门语言与学习如何使用一门语言是不一样的,但它代表了学习的内容(或者在阅读别人的代码时,有多少东西会让你感到困惑)。

精简指令集计算机vs 复杂指令集计算机

Go提供了一组小的正交原语,它们以清晰的预期方式相互作用。学习少量的原语,并与Scala相比,用更多的代码行构建所需的内容。
Scala提供了大量类型和语法的工具箱。学习大量的原语,知道什么时候使用每一个,并且与Go相比,您将能够编写更少的代码行。

文件

我找到了更容易学习的方法,都是因为它是一种更简单的语言,而且是主观的因为我觉得文档更好。
展示:
http://docs.scala-lang.org/tutor...

vs
http://tour.golang.org/#1
http://golang.org/doc/effective_...

常见问题解答:
http://docs.scala-lang.org/tutor...
vs
http://golang.org/doc/faq

Standard library:
http://www.scala-lang.org/api/cu...
vs
http://golang.org/pkg/

表现能力

考虑到语言规范,Scala有比Go更多的特性也就不足为奇了。

Go的一个特点是它没有多余的功能,老实说,我认为它的功能被低估了。
http://golang.org/doc/faq#Why_do...

这是否意味着Go比Scala更缺乏表现力?
不。
表达性是指“有效传达思想或感觉”;这并不意味着“哪种语言最具特色”。在实践中,代码的表现力更多地取决于作者而不是使用的语言。
代码密度可能会对表达性产生反作用。

模拟城市效果

别用谷歌搜索,我只是编出来的。你知道模拟城市,对吧?
SimCity Official Website

如果两个人在同一张地图上建立一个新城市,再经营几个小时,他们就会生产出截然不同的城市。

这是为什么呢?
因为模拟城市像是一个沙箱,有太多的选择,所以任何两个人都会做出同样的决定,这是非常不可能的事情。
Scala也是一个沙箱。
除了Scala附带的大量特性(函数式编程特性、OO编程特性等)之外,Scala还公开了允许开发人员添加新特性的功能。
这一切都很好,除非你和别人分享你的沙盒,否则他们不知道你脑子里在想什么。

代码的一致性

Go是我所知道的唯一一种通过提供一种工具以规范格式对代码进行格式化的方法,从而规避了整个代码风格的争论。
http://golang.org/cmd/gofmt/

代码密度

在学习的早期阶段,Scala代码可能会非常的密集和困难。我想说的是,在Scala中尽可能地密集是很有经验的,或者至少是经验丰富的Scala开发人员有一种简洁的倾向。

第 2 段(可获 8.68 积分)

例如

考虑从cookie获取用户ID。 你需要多少语言知识来回答如何实现下列问题?

  • 如果cookie不存在会发生什么?
  • 如果cookie值不是格式化好的数字会发生什么?
  • 如果cookie值是负数会发生什么?

Scala

import play.api.mvc.RequestHeader

def getUserId()(implicit request: RequestHeader) = {
request.cookies.get("uid").map(_.value.toLong).filter(_ > 0)
}

Go

import (
"fmt"
"http"
"strconv"
) func getUserId(r *http.Request) (int64, error) {
c, err := r.Cookie("uid")
if err != nil {
return 0, err
}
i, err := strconv.ParseInt(c.Value, 10, 64)
if err != nil {
return 0, err
}
if i <= 0 {
return 0, fmt.Errorf("invalid user id")
}
return i, nil
}
第 3 段(可获 0.7 积分)

在这种特殊情况下, Scala代码很短也许更有说服力, 但有一点我想说明一般来说 Go的代码是显式的而Scala的代码需要上下文来理解。

显示的$#%!ing

根据我的经验,显式代码有很多好处。

  • 显式代码更易于让新手和非作者精神交流。
  • 显式代码更易于编辑小的变更。
  • 显式代码使错误情况更清晰。
  • 显式代码使测试用例清晰。
  • 显式代码更容易调试 (尝试在之前Scala代码中设置断点 ).
第 4 段(可获 1.28 积分)

我发现Go的代码比Scala清晰的多。

性能

作为一名开发者,性能是我在开发周期中唯一所关心的, 因为我不想遇到一个在我想做到什么的时候而不够快的运行时。无论如何开发者的时间比电脑的时间更有价值。

根据我的经验, Go编译非常块, Scala则相对慢些。因人而异。

说句公道话

我在学Scala之前先学习的Go,所以我承认我更倾向GO。我对Go第一反应是它的语法很难看 (像C++) 但是学习Go的感觉像这样:

我是出于必要学习的Scala并且已经习惯了它;我现在甚至喜欢上它的一部分, 但学习Scala是这种感觉:

Go 语言和 Scala 语言对比的更多相关文章

  1. IOS-2-C语言和Objective-C语言衔接学习资料

    前言:在IOS学习中.通常会先学习一周的C语言,两周的Objective-C语言,这是今后开发的最基础最重要的部分,以下给大家分享一下培训课上的精简资料: C语言和Objective-C语言衔接学习资 ...

  2. 混合使用C++语言和Objective-C语言

    如果你的源文件扩展名是.m的,你还需要改成.mm,这样编译器才知道你将会在该文件中混合使用C++语言和Objective-C语言.

  3. C语言和Python语言在存储变量方面的不同

    C语言和Python语言在存储变量方面的不同 众所周知,Python是脚本语言,边解释边执行,而C语言是编译型语言 存储变量: C语言定义变量,变量本身代表的就是大小,任何一个字母或者数字 符号均可以 ...

  4. 开发电商平台用PHP语言和JAVA语言有什么区别?哪种语言更好?

    现在很多行业都通过电子商务拓展业务,所以商城系统开发成为很多企业的刚性需求.一般有一点技术基础的客户应该知道目前商城系统开发主流语言有两个,PHP和Java.那么很多客户朋友会纠结是选择哪个语言开发好 ...

  5. C语言和go语言之间的交互

    一.go代码中使用C代码 go代码中使用C代码,在go语言的函数块中,以注释的方式写入C代码,然后紧跟import "C" 即可在go代码中使用C函数 代码示例: go代码:tes ...

  6. C语言和go语言之间的交互 - C语言中使用go语言,使用的go语言又使用了c语言

    一.go语言中使用C语言 go代码中使用C代码,在go语言的函数块中,以注释的方式写入C代码,然后紧跟import “C” 即可在go代码中使用C函数 代码示例: go代码:testC.go 1 pa ...

  7. Unicode与UTF-8互转(c语言和lua语言)

    1. 基础 1.1 ASCII码 我们知道, 在计算机内部, 全部的信息终于都表示为一个二进制的字符串. 每个二进制 位(bit)有0和1两种状态, 因此八个二进制位就能够组合出 256种状态, 这被 ...

  8. Java语言和C++语言的差异

    Java采用了C及C++的语法格式,对于学习过C及C++的程序设计者来说,学习Java将有可能很轻松.但是,如果仔细检查Java语言的许多细节,就会发现Java取消了不少C及C++的特性,并且加入了一 ...

  9. 【C语言学习趣事】_33_关于C语言和C++语言中的取余数(求模)的计算_有符号和无符号数的相互转换问题

    最近再次复习C++语言,用的教材是<C++ Primer>这本教材, 看到第二章的时候,里面有个问题困扰了我. 于是想上网查查怎么回事, 结果看了很久都没有得到一个满意的答案. 书上有这么 ...

随机推荐

  1. Tomcat异常及解决办法——持续更新中

    公司项目,开发语言为java,中间件为Tomcat,运行过程中,从Tomcat出现了一些异常,现将异常及解决办法记录如下,仅供参考.(不断在补充中.......) 异常一: 1.日志内容 org.ap ...

  2. Azure系列2.1 —— com.microsoft.azure.storage.blob

    网上azure的资料较少,尤其是API,全是英文的,中文资料更是少之又少.这次由于公司项目需要使用Azure,所以对Azure的一些学习心得做下笔记,文中不正确地方请大家指正. Azure Blob ...

  3. ArrayList性能短板深入分析

    ArrayList的数据结构主体是Object[]数组,数组对象在内存的位置是成块成块的. 1.对数组进行非尾部修改,会引发System.arrayCopy()行为.这就需要对后半部要移动的对象进行内 ...

  4. NOIP2015提高组复赛B 子串

    题目链接:https://ac.nowcoder.com/acm/contest/263/B 题目大意: 略 分析: 设preA(i)为字符串A中第1个字符到第i个字符构成的字符串. 设preB(i) ...

  5. hadoop 管理命令dfsadmin

    hadoop 管理命令dfsadmin dfsadmin 命令用于管理HDFS集群,这些命令常用于管理员. 1. (Safemode)安全模式 动作 命令 把集群切换到安全模式 bin/hdfs df ...

  6. springboot的几种启动方式

    一:IDE 运行Application这个类的main方法 二:在springboot的应用的根目录下运行mvn spring-boot:run 三:使用mvn install 生成jar后运行 先到 ...

  7. 安装使用阿里云的yum源

    CentOS 1.备份(备份本地Yum源) mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak 2.下 ...

  8. Java集合和数组的区别

    参考:Java集合和数组的区别 集合和容器都是Java中的容器. 区别 数组特点:大小固定,只能存储相同数据类型的数据 集合特点:大小可动态扩展,可以存储各种类型的数据   转换 数组转换为集合: A ...

  9. github & markdown & collapse & table

    github & markdown collapse & table https://github.com/Microsoft/TypeScript/issues/30034 GitH ...

  10. tomcat 和jboss区别

    参考http://blog.csdn.net/sz_bdqn/article/details/6762175