Go语言的应用

Python013

Go语言的应用,第1张

Go语言由Google公司开发,并于2009年开源,相比Java/Python/C等语言,Go尤其擅长并发编程,性能堪比C语言,开发效率肩比Python,被誉为“21世纪的C语言”。

Go语言在云计算、大数据、微服务、高并发领域应用应用非常广泛。BAT大厂正在把Go作为新项目开发的首选语言。

Go语言应用范围:

1、服务端开发:以前你使用C或者C++做的那些事情,用Go来做很合适,例如日志处理、文件系统、监控系统等

2、DevOps:运维生态中的Docker、K8s、prometheus、grafana、open-falcon等都是使用Go语言开发

3、网络编程:大量优秀的Web框架如Echo、Gin、Iris、beego等,而且Go内置的 net/http包十分的优秀

4、Paas云平台领域:Kubernetes和Docker Swarm等

5、分布式存储领域:etcd、Groupcache、TiDB、Cockroachdb、Influxdb等

6、区块链领域:区块链里面有两个明星项目以太坊和fabric都使用Go语言

7、容器虚拟化:大名鼎鼎的Docker就是使用Go语言实现的

8、爬虫及大数据:Go语言天生支持并发,所以十分适合编写分布式爬虫及大数据处理。

Go的内存回收还不是很完善。这对内存捉鸡的移动设备是不小的弊端,因为内存贵而且越大越费电。虽说JAVA内存管理也好不到哪去,但是在对性能敏感的地方可以换JNI。

所以性能上Go是很尴尬的。

加上Go的资源不如JAVA丰富,IDE不如IntelliJ 成熟,Go用来开发只是说说而已。

所以开发效率Go根本不能和JAVA比。

个人认为Google目前需要的是类C#的兼具功能、性能、可移植性强的Native语言。