站在山顶上看golang的前世今生与未来展望

Go前景

Tiobe编程语言2021年10月排行榜

目前go的开发人员是比较缺的,所以对于工作经验的要求不太高。

市场强劲需求

Go语言优势

  1. 兼顾C语言级别的编译、运行效率,容易部署,PHP级别的开发效率
  2. 强大的标准库,内置高效的垃圾回收机制
  3. 简单的并发编程,goroutine和channel极易上手
  4. 静态类型语言,拥有强大的编译检查、严格的编码规范
  5. 背景强大,由三位骨灰级大师创造,google公司运营维护

Go语言的劣势

  1. 没有异常处理,只有Error
  2. 依赖管理(已解决√) 1.11推出GoModules
  3. 缺少框架(已解决√)Gin、Beego、Echo…等等
  4. 无泛型(正在解决。。。)官博确认正在考虑泛型设计,最快在1.18测试版中加入

Go语言前景

  1. 在云计算、微服务、基础后端软件上具有强大优势
  2. 得到诸多大厂的"青睐",很多部门由java转golang,新公司甚至直接使用golang
  3. 优秀开源项目不断涌现,以docker和k8s为代表

1. Go语言的核心开发团队-三位大牛

  • Ken Thompson(肯·汤普逊):1983年图灵奖、1998年美国国家技术奖得主,他与Dennis Ritchie是Unix系统的原创者。Thompson也发明了C语言、B语言,同时也是C语言的主要发明人。
  • Rob Pike(罗布·派克): 加拿大人,曾是贝尔实验室的Unix团队和Plan 9操作计划的成员。他与Thompson公事多年,并共创出广泛使用的UTF-8字元编码。(ps:Go语言的图标-gopher 囊地鼠,是Rob Pike老婆制作的)
  • Robert Griesemer:曾协助制作Java的HotSpot编译器,和Chrom浏览器的JavaScript引擎V8.

2. Go语言的诞生

  • 计算机硬件技术更新频繁,性能提高很快。目前主流的编程语言发展明显落后于硬件,不能合理利用多核多CPU的优势提升软件系统性能。
  • 软件系统复杂度越来越高,维护成本越来越高,目前缺乏一个足够简洁高效的编程语言。
  • 企业运行维护很多c/c++的项目,C/C++程序运行速度虽然很快(因为采用静态编译),但是编译速度却很慢,同时还存在内存泄露的一系列困扰需要解决。

3. Go相关网址

在线教程——文档
Go by Example
菜鸟教程Go语言教程

4. golang各版本的主要功能

Gopher抱怨最多的三大问题如下:

  • 包依赖管理 go1.11开始有好转
  • 缺少泛型 规划实现中,预计在1.18的版本
  • 错误处理 个人感觉还是不太理想
    下载链接:https://golang.google.cn/dl/
主要版本 发布时间 release notes
go1.10 2018.02.17 https://golang.org/doc/go1.10
go1.11 2018.08.25 https://golang.org/doc/go1.11
go1.12 2019.02.16 https://golang.org/doc/go1.12
go1.13 2019.09.04 https://golang.org/doc/go1.13
go1.14 2020.02.14 https://golang.org/doc/go1.14
go1.15 2020.08.12 https://golang.org/doc/go1.15
go1.16 2021.02.17 https://golang.org/doc/go1.16
go1.17 2021.08.17 https://golang.org/doc/go1.17

Golang可以做的事情

  • 区块链研发工程师
    区块链的核心思想是去中心化,让每个人都能参加数据库的记录,比如虚拟货币
  • Go服务端
    目前服务器端主要采用C和C++实现,只要是C和C++能做的事情,Go语言就可以实现且做的不错。因为Go的作者Ken Thompson也是C语言的设计者,相当于对C语言设计的部分优化,比如处理日志、数据打包、虚拟机处理等,据说美团后台的流量处理就是采用Go语言编写。Go语言据处理和大并发处理的能力非常突出
  • 游戏软件工程师
    游戏数据通道会使用Go语言
  • Golang分布式/云计算软件工程师
    盛大云CDN、京东分布式文件系统

5. Go语言开源框架

  • dubbo-go Apache Dubbo Go 语言实现,架起 Java 和 Golang 之间的桥梁,与 gRPC/* Spring Cloud 生态互联互通,带领 Java 生态享受云原生时代的技术红利
  • NSQ 实时分布式消息平台
  • NATS 云原生消息中间件
  • sarama Kafka 客户端
  • InfluxDB 时间序列数据库
  • Thanos 支持 Prometheus 简化部署、高可用、分布式存储
  • CockroachDB 分布式 SQL 数据库
  • RadonDB 基于 MySQL 研发的新一代分布式关系型数据库
  • TiDB 分布式关系型数据库,兼容 MySQL 协议
  • AresDB Uber 开源的 GPU 驱动的实时分析存储&查询引擎
  • leveldb LevelDB 的 Go 实现
  • GCache golang的内存缓存库。支持多种驱逐政策:LRU、LFU、ARC
  • go-cache Go的内存键:值存储/缓存(类似于Memcached)库,适用于单机应用程序。
  • groupcache 分布式缓存
  • cachego 支持 Redis、Bolt 等缓存接口
  • go-tagexpr 字节跳动开源的结构体标签表达式解释器
  • goav FFmpeg 视频处理
  • rosedb 基于 bitcask 的 k-v 存储模型,高效、快速、简洁

6. Go语言学习总结

  1. 在线学习教程:比较系统全面,非常适合新手入门学习;
  2. 书籍:毕竟很多人学习一门语言是从书籍开始的;
  3. 其他Go语言的整理资源:很多比较好的Go语言资源总结整理,推荐看;
  4. Go语言中文社区:专门的Go语言中文社区,可以交流讨论,感兴趣的可以看看;
  5. 其他:其他与Go语言相关的一些整理;

7. 开发工具

常用的Go开发工具如下图所示:

  • Visual Studio Code
    微软的产品,一个运行于Mac OS、Windows和Linux之上的工具,默认提供G语言的语法高亮。安装Go语言插件,还可以支持智能提示,编译运行等功能。

  • Sublime Text
    可以免费试用,默认也支持Go代码语法高亮,只是保存次数达到一定数量后需要购买。

  • Vim
    它是从vi(Linux)发展出来的一个文本编辑器,代码补全、编译及错误跳转等方便编程的功能非常丰富。

  • Emacs
    它不仅仅是一个编辑器,因为功能强大,可称为集成开发环境。

  • Eclipse IDE工具
    开源免费,并提供GoEclipse插件。

  • LiteIDE
    LiteIDE是一款专门为Go语言开发的跨平台轻量级集成开发环境(IDE),是国人开发的。

  • JetBrains公司的产品
    PhpStrom、WebStrom和PyCharm等IDE工具,都需要安装Go插件。