Go语言简介
Go语言设计的初衷
- 针对其他语言的痛点进行设计
- 并加入并发编程
- 为大数据,微服务,并发而生的通用编程语言
维基百科
介绍
Go(又称Golang
)是Google开发的一种静态强类型
、编译型
、并发型
,并具有垃圾回收功能
的编程语言。罗伯特·格瑞史莫
,罗勃·派克(Rob Pike)
及肯·汤普逊
于2007年9月开始设计Go,稍后Ian Lance Taylor
、Russ Cox
加入项目。Go是基于Inferno操作系统所开发的。Go于2009年11月正式宣布推出,成为开放源代码项目,并在Linux及Mac OS X平台上进行了实现,后来追加了Windows系统下的实现。 在2016年,Go被软件评价公司TIOBE
选为“TIOBE 2016 年最佳语言”。 目前,Go每半年发布一个二级版本(即从a.x升级到a.y)。
描述
Go的语法接近C语言
,但对于变量的声明有所不同。Go支持垃圾回收功能
。Go的并行模型是以东尼·霍尔的通信顺序进程(CSP)
为基础,采取类似模型的其他语言包括Occam
和Limbo
,但它也具有Pi运算的特征,比如通道传输。在1.8版本中开放插件(Plugin)的支持,这意味着现在能从Go中动态加载部分函数。
与C++相比,Go并不包括如枚举
、异常处理
、继承
、泛型
、断言
、虚函数
等功能,但增加了 切片(Slice) 型
、并发
、管道
、垃圾回收
、接口(Interface)
等特性的语言级支持。Go 2.0版本将支持泛型
,对于断言的存在,则持负面态度,同时也为自己不提供类型继承来辩护。
不同于Java,Go内嵌了关联数组
(也称为哈希表(Hashes
)或字典(Dictionaries)
),就像字符串类型一样。
撰写风格
在Go中有几项规定,而且这些是强制
的,当不匹配以下规定时编译将会产生错误。
- 每行程序结束后不需要撰写分号(;)。
- 大括号({)不能够换行放置。
- if判断式和for循环不需要以小括号包覆起来。
Go亦有内置gofmt
工具,能够自动整理代码多余的空白、变量名称对齐、并将对齐空格转换成Tab。
目录结构
目录用途src引用的外部库pkg编译时,生成的对象文件bin编译后的程序
特色
Go的主要的功能在于令人简易使用的并行设计,这个方法叫做Goroutine,透过Goroutine能够让程序以异步的方式运行,而不需要担心一个函数导致程序中断,因此Go也非常地适合网络服务。
假设有个程序,里面有两个函数:
func main() {
// 假设 loop 是一个会重复执行十次的回圈函式。
// 回圈执行完毕才会往下执行。
loop()
// 执行另一个回圈。。
loop()
}
这个时候透过Go让其中一个函数同步运行,如此就不需要等待该函数运行完后才能运行下一个函数。
func main() {
// 透过 go,我们可以把这个函式同步执行,
// 如此一来这个函式就不会阻塞主程式的执行。
go loop()
// 执行另一个回圈。
loop()
}
Goroutine
是类似线程的概念(但Goroutine并不是线程)。线程属于系统层面,通常来说创建一个新的线程会消耗较多的资源且管理不易。而 Goroutine就像轻量级的线程,但我们称其为并发,一个Go程序可以运行超过数万个 Goroutine,并且这些性能都是原生级的,随时都能够关闭、结束。一个核心里面可以有多个Goroutine,透过GOMAXPROCS
参数你能够限制Gorotuine可以占用几个系统线程来避免失控。
在内置的官方包中也不时能够看见Goroutine的应用,像是net/http中用来监听网络服务的函数实际上是创建一个不断运行循环的Goroutine。
有哪些大公司正在使用
作为开发Go语言的google公司,当仁不让。Google基于Go有很多优秀的开源项目,比如kubernets,docker。大家可以移步到google查看更多的Google的Go开源项目。
Facebook也在用,为此他们还专门在Github上建立了一个开源组织facebookgo
腾讯
腾讯作为国内的大公司,还是敢于尝试的,尤其是Docker容器化这一块,他们在15年已经做了Docker万台规模的实践
百度
目前所知的百度的使用是在运维这边,是百度运维的一个BFE项目,负责前端流量的接入。他们的负责人在2016年有分享。
阿里
阿里巴巴具体的项目不太清楚,不过听说其系统部门、CDN等正在招Go方面的人。
京东
京东云消息推送系统
、云存储
,以及京东商城
等都有使用Go做开发。
小米
小米对Golang的支持,莫过于运维监控系统的开源,此外,小米互娱
、小米商城
、小米视频
、小米生态链
等团队都在使用Golang。
360
360对Golang的使用也不少,一个是开源的日志搜索系统
Poseidon,还有360的推送团队也在使用,他们还写了篇博文在Golang的官方博客上,最后偷偷的告诉你,360直播在招聘Golang开发工程师。
其他
现在很多公司都开始尝试Golang,除了上面提到的,还有美团、滴滴、新浪以及七牛云等。一般的选择,都是选择用于自己公司合适的产品系统来做,比如消息推送
、监控
、容器
等,Golang特别适合做网络并发的服务,这是他的强项,所以也是被优先用于这些项目。
其次就是用于替换一些以前使用PHP、Python、C/C++的项目,这些迁移到Golang还是比较容易的,不过目前旧系统迁移的不是太多,主要是新系统的使用。
参考链接:
https://zh.wikipedia.org/wiki/Go
http://www.flysnow.org/2017/09/13/go-for-company.html
文章可能存在不足之处,欢迎大家指出。