为什么会设计Go语言
当初他们为什么会有设计一个新语言的冲动呢?让我们一起来回顾一下这些历史,也许很多人对他们当年遇到的问题感同身受。
设计Go语言是为了解决当时Google开发遇到的以下这些问题:
-
大量的C++代码,同时又引入了Java和Python
-
成千上万的工程师
-
数以万计行的代码
-
分布式的编译系统
-
数百万的服务器
其主要有以下几个方面的痛点:
-
编译慢
-
失控的依赖
-
每个工程师只是用了一个语言里面的一部分
-
程序难以维护(可读性差、文档不清晰等)
-
更新的花费越来越长
-
交叉编译困难
所以,他们当时设计Go的目标是为了消除各种缓慢和笨重、改进各种低效和扩展性。Go是由那些开发大型系统的人设计的,同时也是为了这些人服务的;它是为了解决工程上的问题,不是为了研究语言设计;它还是为了让我们的编程变得更舒适和方便。
但是结合Google当时内部的一些现实情况,如很多工程师都是C系的,所以新设计的语言一定要易学习,最好是C-like的语言;因为有太多的分布式系统、太多的开发者,所以新的语言一定要可以Scale,这个包括开发、工程师、代码、部署和依赖;20年没有出新的语言了,所以新设计的语言必须是现代化的(例如内置GC)等情况,他们觉得要实现这个目标就需要Go成为一个大家都认可的语言。
最后根据实战经验,他们向着目标设计了Go这个语言,其主要的特色有:
-
没有继承的OO
-
强一致类型
-
Interface但是不需要显示申明(Duck Type)
-
Function 和Method
-
没有异常处理(Error is value)
-
基于首字母的可访问特性
-
不用的Import或者变量引起编译错误
-
完整而卓越的标准库包
Go发布之后,很多公司特别是云计算公司开始用Go重构他们的基础架构,很多都是直接采用Go进行了开发,最近热火朝天的Docker就是采用Go开发的。我们来看看目前为止采用Go的一些国内外公司,国外的如Google、Docker、Apple、Cloud Foundry、CloudFlare、Couchbase、CoreOS、Dropbox、MongoDB、AWS等公司,国内的如阿里云CDN、百度、小米、七牛、PingCAP、华为、金山软件、猎豹移动、饿了么等公司
有疑问加站长微信联系(非本文作者)