乐趣区

Go-笔记之为什么要学-Go


title: Go 笔记之为什么要学 Go

新学一门语言,大家都想先弄清楚为什么要学它?玩知乎一段时间更是让我感受深刻,诸如

  • 为什么要学习 Python?
  • 为什么要学习 C?
  • 为什么要学习 Java?

之类问题经常出现在眼前。以前学语言时倒没怎么关心过这类问题。今年公司由于新业务需要开始全面从 PHP 转型到 Golang。所以我学习它也就是为了工资。额?不能这么俗气,还是具体想想自己为什么要学习 Golang 吧。

作为一名 golang 新人,在写这篇文章时我搜罗到不少 golang 的优秀资料,在文章最后分享出来。

大势所趋

趋势如此,这应该是多数朋友开始学习它的原因。追涨杀跌,这是大多数人喜欢的操作手法。

何以证明这个趋势呢?

首先,我的亲生经历是听到看到 golang 这个词的频率越来越高,不过,这个太难量化了。来介绍一款工具,google trend,即 google 趋势。它是 google 利用自身优势,通过对搜索关键词进行统计分析,根据单词频率分析特定时期某类事物发展趋势的一款分析工具。

我们可以用 google 趋势来分析一下近年来 golang 的发展趋势,点击链接。

先看看时间线上的表现,历史的变化趋势:

可以看出,从 2015 年到 2019 年 golang 的发展趋势一直处在稳定上升阶段;

不过我们会想,这只能说明 golang 在世界上整体趋势表现较好,但在中国是否一样火热。这个大可不必担心,google 趋势中也有区域的统计信息:

可以看出,Golang 在世界区域的分布情况,前五名分别是,中国、新加坡、圣赫勒拿、韩国、香港。其中,Golang 在中国的流行程度简直就是一骑绝尘、遥遥领先。

注:如果想分析中国各城市的表现情况,可以点击地图就可进入特定国家进行分析。

除了 google 趋势,还可以来看看在 TIOBE 语言排行榜上的表现。点击链接

额?怎么才十六名,好紧张、好难过,难道学错语言了吗?不对,得找几个理由安慰下自己。

Golang 是一门非常年轻的语言,仅用十年时间就从世界上数以千计的编程语言中脱颖而出,发展速度迅猛。诸如 Java、Python、PHP、Javascript 都和我一样处在了奔三的路上,近 30 载的发展才有当前的生态与地位;

Golang 在 2018 年的最好成绩曾到达过前十名,这个成绩足以说明 golang 的流行程度。而且排名存在浮动也是很正常的事情,Golang 这些年稳步的发展趋势还不能给我们足够的信心吗?

通过以上的数据分析,我们得到了一些结论,不过感觉说服力不足,有种空喊口号 “ 我们能赢 ” 的感觉。趋势很好,就认为稳赢,显然这是很不合理的。所以,我们还需要分析一些更层次的原因。

核心成员

为什么要了解核心成员呢?核心成员某种意义上是语言的招牌。就像投资,肯定选择相信巴菲特,而不是你。

Golang 的核心开发组成员由一群大神级人物组成。其中,最核心的三人分别是 Ken Thompson、Rob Pike、Robert Griesemer。

Robert Griesemer,参与开发了 Java HotSpot 虚拟机和 Javascript 的 Chrome V8 引擎;

Ken Thompson,C 和 B 语言的设计者、Unix 创始人之一,操作系统 Plan 9 的主要作者,1983 年图灵奖得主;

Rob Pike,UTF8 的主要设计者,与 Ken Tompson 为贝尔实验室的同事,共同参与了 Plan9。而且 Golang 的 logo,据说是囊地鼠,英文 gopher,就是 Rob Pike 的妻子设计的;

都是如此这般牛人坐镇,可见 golang 的层次已经高出其他语言很多个台阶了。

背景历史

清楚它的产生背景与发展历史,才能更好了解它的特性与使用场景。

首先,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 重构推荐系统?

很多涉及领域就不一一列举了。反正一句话就是很牛。

学习资料

说这么多,主要是为给自己好好学习找个借口。接下来分享一些近期收集的 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 文章和书籍资料;
  • go 交流论坛,gocn.vip,go 语言学习交流论坛;
  • go 官方讨论组,forum/golang-nuts,golang 的官方邮件讨论组;

一张图、一个目录与一个合集

在整理资料时,发现太多优秀的开源项目与书籍,重复工作就不做了,分享几个别人整理的优秀资源。如下:

  • 一个目录:索引目录地址,各种 go 语言资源的汇总;
  • 一张图谱:图谱 processon 地址,源自 Golang Foundation;
  • 一个合集:awesome-go,其中整理了大量 golang 的库、框架和一些著名项目;
退出移动版