站在山顶上看golang的前世今生与未来展望
-
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相关网址
-
Go语言官方网址
官网里面新手推荐看: -
A Tour of Go(Go语言编程指南)(中文版本在这里: Go 指南):主要是带你了解基础的Go语言和使用方法,重点是有个在线编译器,可以在浏览器里面写Go语言,直观感受Go语言;
-
How to Write Go Code:也是带你入门学习Go语言的,类似教程吧,英文的,新手同样可以看;
-
https://golang.org/ref/spec: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语言学习总结
- 在线学习教程:比较系统全面,非常适合新手入门学习;
- 书籍:毕竟很多人学习一门语言是从书籍开始的;
- 其他Go语言的整理资源:很多比较好的Go语言资源总结整理,推荐看;
- Go语言中文社区:专门的Go语言中文社区,可以交流讨论,感兴趣的可以看看;
- 其他:其他与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插件。