“谢孟军:EGO会员、GophrChina组织者、《GoWb编程》一书的作者,专注Golang技术架构。本文来自EGO会员群分享,入群方式见文末 在这里我主要想和大家分享一些Go和我个人的成长史。首先聊聊Go,在年全部开源出来后,它获得了当年的年度语言,但是直到年它才发布正式的稳定版本。Go稳定版发布时,GoTam承诺后续的版本都会兼容之前的版本。这对于我们开发者来说简直太重要了,Go后续的版本也一直在提升内功,从而可以让我们无缝的升级Go版本。 Go的核心贡献者Go主要有静态语言、天生并发、内置GC、安全性高、语法简单、交叉编译和编译快速这几个方面的特性。这些特性决定了Go的三个高富帅特性:运行快、开发快和部署快,而这些特性都是针对Googl遇到的一些痛点来设计的。 图1 在说痛点之前,我们先来了解一下Go的作者和主要核心开发者们,图1是Go的三个作者从左到右分别是:RobrtGrismr,RobPik和KnThompson。Robrt在开发Go之前是GooglV8、Chubby和HotSpotJVM的主要贡献者;Rob主要是Unix、UTF-8、plan9的作者;Kn主要是B语言、C语言的作者、Unix之父。 图2 再来看看其他核心贡献者,图2中RussCox也是目前Go的领导者之一,他和RobPik一起领导Go;IanLancTaylor是GCC的作者之一,目前负责GCC的Go实现;BradFitzpatrick之前是Mmcach的作者,目前主要是HTTP2的实现作者。大家可以看到这些作者都是各个领域内的顶尖高手,所以当初我相信一群牛人做出来的Go也一定够牛。 为什么会设计Go语言?当初他们为什么会有设计一个新语言的冲动呢?让我们一起来回顾一下这些历史,也许很多人对他们当年遇到的问题感同身受。 设计Go语言是为了解决当时Googl开发遇到的以下这些问题: 大量的C++代码,同时又引入了Java和Python 成千上万的工程师 数以万计行的代码 分布式的编译系统 数百万的服务器 其主要有以下几个方面的痛点: 编译慢 失控的依赖 每个工程师只是用了一个语言里面的一部分 程序难以维护(可读性差、文档不清晰等) 更新的花费越来越长 交叉编译困难 所以,他们当时设计Go的目标是为了消除各种缓慢和笨重、改进各种低效和扩展性。Go是由那些开发大型系统的人设计的,同时也是为了这些人服务的;它是为了解决工程上的问题,不是为了研究语言设计;它还是为了让我们的编程变得更舒适和方便。 但是结合Googl当时内部的一些现实情况,如很多工程师都是C系的,所以新设计的语言一定要易学习,最好是C-lik的语言;因为有太多的分布式系统、太多的开发者,所以新的语言一定要可以Scal,这个包括开发、工程师、代码、部署和依赖;20年没有出新的语言了,所以新设计的语言必须是现代化的(例如内置GC)等情况,他们觉得要实现这个目标就需要Go成为一个大家都认可的语言。 最后根据实战经验,他们向着目标设计了Go这个语言,其主要的特色有: 没有继承的OO 强一致类型 Intrfac但是不需要显示申明(DuckTyp) Function和Mthod 没有异常处理(Errorisvalu) 基于首字母的可访问特性 不用的Import或者变量引起编译错误 完整而卓越的标准库包 Go发布之后,很多公司特别是云计算公司开始用Go重构他们的基础架构,很多都是直接采用Go进行了开发,最近热火朝天的Dockr就是采用Go开发的。我们来看看目前为止采用Go的一些国内外公司,国外的如Googl、Dockr、Appl、CloudFoundry、CloudFlar、Couchbas、CorOS、Dropbox、MongoDB、AWS等公司,国内的如阿里云CDN、百度、小米、七牛、PingCAP、华为、金山软件、猎豹移动、饿了么等公司。 Go主要应用的系统上面那些基本上就是Go的历史背景和设计初衷,那么目前Go主要应用于哪些系统呢? 就我知道的来说,目前Go主要应用在下面这些系统: 服务器编程,以前你如果使用C或者C++做的那些事情,用Go来做很合适,例如处理日志、数据打包、虚拟机处理、文件系统等。 分布式系统、数据库代理器等,例如Etcd。 网络编程,这一块目前应用最广,包括Wb应用、API应用、下载应用,而且Go内置的nt/治疗白癜风最好的药膏北京哪家医院白癜风手术好
|