GO语言背景历史
清楚它的产生背景与发展历史,才能更好了解它的特性与使用场景。
首先,Golang诞生于google。有了大厂庇护,才好开挂。google曾经一直有个传统,允许员工自由支配本属于工作时间的20%来用于创新实践,这为google带来很多开创性的项目,其中就包括Golang。但听说,前几年该传统已经被取消了。
Golang早起的讨论由前面介绍的三位大牛发起,针对性分析了当时的环境背景。
首先,当时传统的编程语言通常都会有如下一些缺点:
- 学习成本太高,如C++,为准确表达作者思想,我们要花费大量时间学习语言;
- 编译速度太慢,代码的编写、预处理、编译与运行流程花费时间太长;
- 缺乏类型检查,主要指诸如python、php等解释性语言,这常会导致一些低级错误发生;
而且计算机领域相比于前些年也发生了很多变化,比如:
- 计算机硬件发展迅速,软件已经不能充分发挥它们的优势,比如多CPU;
- 语言越来越复杂,要么并发与性能不佳,要么风格不够优雅且不统一;
- 人力成本越高越贵,项目的迭代周期越来越短;
针对如上的各种情况,于是在2007年,他们正式开始着手Golang的设计与开发,并在2009年的11月正式发布。我们列举下,接下来一段时间,Golang发展中几个关键节点。
- 2012年3月,正式发布1.0版,走向成熟;
- 2015年8月,发布了1.5版,实现自编译,移除最后残余的 "C代码";
更新迭代速度多,基本保持了每半年更新一个版本;
- 2017年2月,发布1.8版
- 2017年8月,发布1.9版
- 2018年2月,发布1.10版
- 2018年8月,发布1.11版
- 2019年2月,发布1.12版
如此给力的团队与稳定的版本迭代速度,某种程度也促成了golang快速发展。
语言特性
各种介绍go的文章讲的最多的两点特性:静态语言与高并发。但是取交集的话,特性就太少了。介绍细致些吧,但如此一来,这段就显得很是无聊,
了解golang特性前,可先来看看它的几个设计原则。在网上搜罗了些资料,总结出大概几点:
- 大道至简,比如及其简单但完备的面向对象设计,面向接口,没有继承只有组合;
- 最少特性,一个特性对解决问题有显著效果就没有必要存在;
- 显式表达,比如数据类型必须显式转化,不提供隐式转化能力;
- 最少惊异,减少那些奇怪的特性设计,最大程度减少错误发生概率;
从产生背景我们可以知道,Golang在主要针对其他语言痛点而设计的。它有哪些特性?
- 静态语言、静态编译速度快,拥有静态语言的安全与性能;
- 天然支持并发,基于CPS并发模型,goroutine轻量级线程,支持大并发处理;
- 简洁的脚本化语法,如变量赋值 a := 1,兼具静态语言的特性与动态语言的开发效率;
- 提供垃圾回收机制,不需要开发人员管理,通过循环判活,再启用goroutine来清理内存;
- 创新的异常处理机制,普通异常通过返回error对象处理,严重异常由panic、recover处理;
- 函数多返回值,方便接收多值,一些解释性语言已经支持,如python、js的es6等;
- 支持defer延迟调用,从而提供了一种方式来方便资源清理,降低资源泄露的概率;
- 面向接口的oop,没有对象与继承,强调组合,以类似于duck-typing的方式编写面向对象;
那么多特性,好无聊,不对,应该是好厉害。之前在知乎上看到过有位朋友写了个十分钟GO快速入门的文章,挺有趣的,分享出来。看过之后应该对上面这些特性有更直观的认知。
知乎地址在 GO十分钟快速入门,代码在 GO Play 代码体验。
优秀项目
已经说了那么多Golang的牛x之处,但以前出现过的很多语言也都是这么宣传的。
语言的目标是用于项目开发,并能打造出很多优秀的产品。那么,Golang有哪些好像优秀的项目呢?不搜不知道,一搜吓一跳!列举一下我收集到的golang开发的优秀项目,如下:
- docker,golang头号优秀项目,通过虚拟化技术实现的操作系统与应用的隔离,也称为容器;
- kubernetes,由google开发,简称k8s,k8s和docker是当前容器化技术的重要基础设施;
- etcd,一种可靠的分布式KV存储系统,有点类似于zookeeper,可用于快速的云配置;
- codis,由国人开发提供的一套优秀的redis分布式解决方案;
- tidb,国内PingCAP 团队开发的一个分布式SQL 数据库,国内很多互联网公司在使用;
- influxdb,时序型DB,着力于高性能查询与存储时序型数据,常用于系统监控与金融领域;
- cockroachdb,云原生分布式数据库,继NoSQL之后出现的新的概念,称为NewSQL数据库;
- beego,国人开发的一款及其轻量级、高可伸缩性和高性能的web应用框架;
- caddy,类比于nginx,一款开源的,支持HTTP/2的 Web 服务端;
- flynn,一款开源的paas平台;
- consul,HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置;
- go-kit,Golang相关的微服务框架,这类框架还有go-micro、typthon;
- go-ethereum,官方开发的以太坊协议实现;
- couchbase,是一个非关系型数据库;
- nsq,一款高性能、高可用消息队列系统,每天能处理数十亿条的消息;
- packer,一款用来生成不同平台的镜像文件的工具,例如VM、vbox、AWS等;
- doozer:高速的分布式数据同步服务,类似ZooKeeper;
- tsuru:开源的PAAS平台,和SAE实现的功能一模一样;
- gor:一款用Go语言实现的简单的http流量复制工具;
项目列举了这么多,从此也可看出现在很多新项目都在使用Golang开发,涉及到很多领域。
应用领域
接下来了解下Golang具体擅长哪些领域,如果不适合自己所在行业,暂时就没必要去学习了。
区块链
当前的两个主流区块链框架,分布式记账本框架hyperledger和以太坊合约框架go-ethereum都是使用Golang开发;下图是某招聘网站关于区块链职位要求技能的分析。
微服务
现在越来越多的项目会采用微服务架构,前面介绍的优秀项目中也看到很多go提供的微服务框架,如git-kit、micro等。
举一些具体公司的例子,比如今日头条使用Golang构建了千万级微服务;
云服务
云服务,如国内著名的七牛云全站采用Golang开发;还有如盛大CDN、阿里云CDN等;
很多的云平台基础设施如docker、kubernetes等为Golang开发;
京东的消息推送与分布式存储也是如此;
分布式
诸如数据库中间件、代理服务等很多采用Golang开发,比如前面的介绍codis、cockroachdb、etcd等;
其他
很多领域都能看到Golang的影子,诸如直播领域、游戏开发等等,在其中golang为后台的调度系统、任务处理,批量的数据计算、系统监控等提供了各种解决方案。
比如,最近知乎近也使用Golang进行重构了自己的推荐系统。
舍弃Python,为什么知乎选用Go重构推荐系统? - InfoQwww.infoq.cn
很多涉及领域就不一一列举了。反正一句话就是很牛。
学习资料
说这么多,主要是为给自己好好学习找个借口。接下来分享一些近期收集的Golang学习资料。
Golang官网
Golang官方地址: golang.org,无论学习什么知识,第一手资料基本都是首发于官网。进入到官网后,会看到很多资源,比如:
- 文档:golang.org/doc,官方文档,仔细读下文档首页并分类,了解下自己要学哪些内容;
- 一览:tour.golang.org,交互式运行环境,不安装golang便可体验学习它的语法与使用;
- 指南:golang.org/ref/spec,golang学习指导手册,从基础语法到高级特性全部都有介绍;
- 标准库:golang.org/pkg/,可以查看所有的官方库的接口、源码以及使用介绍;
- 博客:blog.golang.org/,不定期分享go的最佳实践,有些公司也会投稿介绍自己的案例;
- 实验室:play.golang.org,感觉和tour类似,不过在这里编写的代码可以分享给别人;
等等。
官网是个宝库,我们需要认真仔细去挖掘其中的内容;但由于一些原因,golang的官方站点我们无法访问,不过golang为我们提供了中国的官网,地址:golang.google.cn;
golang社区
一门语言的发展需要有大批牛人的分享布道,也需要我们这些菜鸟学习有更多的参考路径。这一切都离不开社区。国内外也有很多优秀的go语言社区;
- go语言中文网,studygolang.com,分享Go 语言知识,聚合各种golang文章和书籍资料;
- beego社区,beego.me/community,国人开发的框架社区;
- go交流论坛,gocn.vip,go语言学习交流论坛;
- go官方讨论组,forum/golang-nuts,golang的官方邮件讨论组;
一张图、一个目录与一个合集
在整理资料时,发现太多优秀的开源项目与书籍,重复工作就不做了,分享几个别人整理的优秀资源。如下:
- 一个目录:索引目录地址,各种go语言资源的汇总;
- 一张图谱:图谱processon地址,源自Golang Foundation;
- 一个合集:awesome-go,受awesome-python启发,整理的golang的库、框架和软件合集;