Go前景

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

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


市场强劲需求


Go语言优势

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


Go语言的劣势

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


Go语言前景

  • 在云计算、微服务、基础后端软件上具有强大优势
  • 得到诸多大厂的"青睐",很多部门由java转golang,新公司甚至直接使用golang
  • 优秀开源项目不断涌现,以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相关网址

  • 官网里面新手推荐看:
  • A Tour of Go(Go语言编程指南)(中文版本在这里: Go 指南):主要是带你了解基础的Go语言和使用方法,重点是有个在线编译器,可以在浏览器里面写Go语言,直观感受Go语言;
  • How to Write Go Code:也是带你入门学习Go语言的,类似教程吧,英文的,新手同样可以看;
  • https://golang.org/ref/spec:Go编程语言的参考手册,英文的;


在线教程——文档


4. golang各版本的主要功能

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

  • 包依赖管理 go1.11开始有好转
  • 缺少泛型 规划实现中,预计在1.18的版本
  • 错误处理 个人感觉还是不太理想

主要版本 发布时间 release notes


5. Golang可以做的事情

  • 区块链研发工程师

区块链的核心思想是去中心化,让每个人都能参加数据库的记录,比如虚拟货币

  • Go服务端

目前服务器端主要采用C和C++实现,只要是C和C++能做的事情,Go语言就可以实现且做的不错。因为Go的作者Ken Thompson也是C语言的设计者,相当于对C语言设计的部分优化,比如处理日志、数据打包、虚拟机处理等,据说美团后台的流量处理就是采用Go语言编写。Go语言据处理和大并发处理的能力非常突出

  • 游戏软件工程师

游戏数据通道会使用Go语言

  • Golang分布式/云计算软件工程师

盛大云CDN、京东分布式文件系统


6. 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 存储模型,高效、快速、简洁


7. Go语言学习总结

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


8. Go语言开发工具

常用的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插件。


9. golang适合做的项目

  • 1.云计算基础设施领域

代表项目:docker、kubernetes、etcd、consul、cloudflare cdn、七牛云存储等

  • 2.基础后端软件

代表项目:tidb、influxdb,cockroachdb

  • 3.微服务

代表项目: go-kit、micro、monzo bank的typhon、bilibili等

  • 4.互联网基础设施

代表项目:以太坊、hyperledger等