Go概述
Go語(yǔ)言是谷歌2009年發(fā)布的第二款開(kāi)源編程語(yǔ)言,它專(zhuān)門(mén)針對(duì)多處理器系統(tǒng)應(yīng)用程序的編程進(jìn)行了優(yōu)化,它是一種系統(tǒng)語(yǔ)言其非常有用和強(qiáng)大,其程序可以媲美C或C++代碼的速度,而且更加安全、支持并行進(jìn)程。
Go支持面向?qū)ο?,而且具有真正的閉包(closures)和反射 (reflection)等功能。
Go可以在不損失應(yīng)用程序性能的情況下降低代碼的復(fù)雜性。
發(fā)表時(shí)間: 2009年
類(lèi) 型: 開(kāi)源編程語(yǔ)言
公 司: 谷歌
官網(wǎng):https://golang.google.cn/
API文檔:https://golang.google.cn/doc/
教程:http://hgci.cn/go/go-tutorial.html
下載:https://golang.google.cn/dl/
目標(biāo)
Go的目標(biāo)是希望提升現(xiàn)有編程語(yǔ)言對(duì)程序庫(kù)等依賴(lài)性(dependency)的管理,這些軟件元素會(huì)被應(yīng)用程序反復(fù)調(diào)用。由于存在并行編程模式,因此這一語(yǔ)言也被設(shè)計(jì)用來(lái)解決多處理器的任務(wù)。
功能特點(diǎn)
- Go語(yǔ)言設(shè)計(jì)是讓軟件充分發(fā)揮多核心處理器同步多工的優(yōu)點(diǎn),它可解決面向?qū)ο蟪绦蛟O(shè)計(jì)面臨的麻煩。
- Go的速度也非???,幾乎和C或C++程序一樣快,且能夠快速制作程序。
- Go支持面向?qū)ο?,而且具有真正的閉包(closures)和反射 (reflection)等功能。
- Go語(yǔ)言可以在不損失應(yīng)用程序性能的情況下降低代碼的復(fù)雜性。
- Go語(yǔ)言的另一項(xiàng)與網(wǎng)絡(luò)相關(guān)的特色,是服務(wù)器和用戶端設(shè)備,如PC或手機(jī),可以分擔(dān)工作。因此,使用Go的服務(wù)便可輕松適應(yīng)不同的用戶端處理性能。
- Go可以和Native Client配合使用,Go可以讓?xiě)?yīng)用完美的運(yùn)行在瀏覽器內(nèi)。例如,使用Go可以更高效的實(shí)現(xiàn)Wave,無(wú)論是在前端還是后臺(tái)。
- Go 同時(shí)具有兩種編譯器,一種是建立在GCC基礎(chǔ)上的Gccgo,另外一種是分別針對(duì)64位x64和32位x86計(jì)算機(jī)的一套編譯器(6g和8g)。谷歌目前正在研發(fā)其對(duì)ARM芯片和Android設(shè)備的支持。
Go有什么優(yōu)勢(shì)
- 可直接編譯成機(jī)器碼,不依賴(lài)其他庫(kù),glibc的版本有一定要求,部署就是扔一個(gè)文件上去就完成了。
- 靜態(tài)類(lèi)型語(yǔ)言,但是有動(dòng)態(tài)語(yǔ)言的感覺(jué),靜態(tài)類(lèi)型的語(yǔ)言就是可以在編譯的時(shí)候檢查出來(lái)隱藏的大多數(shù)問(wèn)題,動(dòng)態(tài)語(yǔ)言的感覺(jué)就是有很多的包可以使用,寫(xiě)起來(lái)的效率很高。
- 語(yǔ)言層面支持并發(fā),這個(gè)就是Go最大的特色,天生的支持并發(fā),Go就是基因里面支持的并發(fā),可以充分的利用多核,很容易的使用并發(fā)。
- 內(nèi)置runtime,支持垃圾回收,這屬于動(dòng)態(tài)語(yǔ)言的特性之一吧,雖然目前來(lái)說(shuō)GC不算完美,但是足以應(yīng)付我們所能遇到的大多數(shù)情況,特別是Go1.1之后的GC。
- 簡(jiǎn)單易學(xué),Go語(yǔ)言的作者都有C的基因,那么Go自然而然就有了C的基因,那么Go關(guān)鍵字是25個(gè),但是表達(dá)能力很強(qiáng)大,幾乎支持大多數(shù)你在其他語(yǔ)言見(jiàn)過(guò)的特性:繼承、重載、對(duì)象等。
- 豐富的標(biāo)準(zhǔn)庫(kù),Go目前已經(jīng)內(nèi)置了大量的庫(kù),特別是網(wǎng)絡(luò)庫(kù)非常強(qiáng)大
- 內(nèi)置強(qiáng)大的工具,Go語(yǔ)言里面內(nèi)置了很多工具鏈,最好的應(yīng)該是gofmt工具,自動(dòng)化格式化代碼,能夠讓團(tuán)隊(duì)review變得如此的簡(jiǎn)單,代碼格式一模一樣,想不一樣都很困難。
- 跨平臺(tái)編譯,如果你寫(xiě)的Go代碼不包含cgo,那么就可以做到window系統(tǒng)編譯linux的應(yīng)用,如何做到的呢?Go引用了plan9的代碼,這就是不依賴(lài)系統(tǒng)的信息。
- 內(nèi)嵌C支持,前面說(shuō)了作者是C的作者,所以Go里面也可以直接包含c代碼,利用現(xiàn)有的豐富的C庫(kù)。
Go適合用來(lái)做什么
- 服務(wù)器編程,以前你如果使用C或者C++做的那些事情,用Go來(lái)做很合適,例如處理日志、數(shù)據(jù)打包、虛擬機(jī)處理、文件系統(tǒng)等。
- 分布式系統(tǒng),數(shù)據(jù)庫(kù)代理器等
- 網(wǎng)絡(luò)編程,這一塊目前應(yīng)用最廣,包括Web應(yīng)用、API應(yīng)用、下載應(yīng)用、
- 內(nèi)存數(shù)據(jù)庫(kù),前一段時(shí)間google開(kāi)發(fā)的groupcache,couchbase的部分組建
- 云平臺(tái),目前國(guó)外很多云平臺(tái)在采用Go開(kāi)發(fā),CloudFoundy的部分組建,前VMware的技術(shù)總監(jiān)自己出來(lái)搞的apcera云平臺(tái)。
Go成功的項(xiàng)目
- nsq:bitly開(kāi)源的消息隊(duì)列系統(tǒng),性能非常高,目前他們每天處理數(shù)十億條的消息
- docker:基于lxc的一個(gè)虛擬打包工具,能夠?qū)崿F(xiàn)PAAS平臺(tái)的組建。
- packer:用來(lái)生成不同平臺(tái)的鏡像文件,例如VM、vbox、AWS等,作者是vagrant的作者
- skynet:分布式調(diào)度框架
- Doozer:分布式同步工具,類(lèi)似ZooKeeper
- Heka:mazila開(kāi)源的日志處理系統(tǒng)
- cbfs:couchbase開(kāi)源的分布式文件系統(tǒng)
- tsuru:開(kāi)源的PAAS平臺(tái),和SAE實(shí)現(xiàn)的功能一模一樣
- groupcache:memcahe作者寫(xiě)的用于Google下載系統(tǒng)的緩存系統(tǒng)
- god:類(lèi)似redis的緩存系統(tǒng),但是支持分布式和擴(kuò)展性
- gor:網(wǎng)絡(luò)流量抓包和重放工具
團(tuán)隊(duì)成員
Thompson:1983年圖靈獎(jiǎng)(Turing Award)和1998年美國(guó)國(guó)家技術(shù)獎(jiǎng)(National Medal of Technology)得主。他與Dennis Ritchie是Unix的原創(chuàng)者。Thompson也發(fā)明了后來(lái)衍生出C語(yǔ)言的B程序語(yǔ)言。
Pike:曾是貝爾實(shí)驗(yàn)室(Bell Labs)的Unix團(tuán)隊(duì),和Plan 9操作系統(tǒng)計(jì)劃的成員。他與Thompson共事多年,并共創(chuàng)出廣泛使用的UTF-8 字元編碼。
Robert Griesemer:曾協(xié)助制作Java的HotSpot編譯器,和Chrome瀏覽器的JavaScript引擎V8。
此外還有Plan 9開(kāi)發(fā)者Russ Cox、和曾改善已廣泛使用之開(kāi)源碼編譯器GCC的Ian Taylor。
Go語(yǔ)言簡(jiǎn)史
- 2007年,谷歌工程師Rob Pike, Ken Thompson和Robert Griesemer開(kāi)始設(shè)計(jì)一門(mén)全新的語(yǔ)言,這是Go語(yǔ)言的最初原型。
- 2009年11月10日,Go語(yǔ)言以開(kāi)放源代碼的方式向全球發(fā)布。
- 2010年1月10日 , Go語(yǔ)言摘得了TIOBE公布的2009年年度大獎(jiǎng)。
- 2011年3月16日,Go語(yǔ)言的第一個(gè)穩(wěn)定(stable)版本r56發(fā)布。
- 2012年3月28日,Go語(yǔ)言的第一個(gè)正式版本Go1發(fā)布
- 2013年4月04日,Go語(yǔ)言的第一個(gè)Go 1.1beta1測(cè)試版發(fā)布。
- 2013年4月08日,Go語(yǔ)言的第二個(gè)Go 1.1beta2測(cè)試版發(fā)布。
- 2013年5月02日,Go語(yǔ)言Go 1.1RC1版發(fā)布。
- 2013年5月07日,Go語(yǔ)言Go 1.1RC2版發(fā)布。
- 2013年5月09日,Go語(yǔ)言Go 1.1RC3版發(fā)布。
- 2013年5月13日,Go語(yǔ)言Go 1.1正式版發(fā)布。
- 2013年9月20日,Go語(yǔ)言Go 1.2RC1版發(fā)布。
- 2014年6月19日,Go語(yǔ)言Go 1.3版發(fā)布。
- 2015年8月20日,Go語(yǔ)言Go 1.5版發(fā)布,本次更新中移除了”最后殘余的C代碼”。
- 2016年2月17日 , Go語(yǔ)言Go 1.6版本發(fā)布,本次開(kāi)始全面支持 HTTP/2 國(guó)際標(biāo)準(zhǔn)。
- 2016年8月15日 , Go語(yǔ)言Go 1.7版本發(fā)布。
2017年2月17日,Go語(yǔ)言Go 1.8版發(fā)布。
2018年2月16日,Go語(yǔ)言Go 1.10版發(fā)布。
2017年8月24日,Go語(yǔ)言Go 1.9版發(fā)布。
支持平臺(tái)
硬件架構(gòu)
Go語(yǔ)言設(shè)計(jì)支持主流的32位和64位的x86平臺(tái),同時(shí)也支持32位的ARM架構(gòu)。
操作系統(tǒng)
Go語(yǔ)言在Go1版本上支持Windows, 蘋(píng)果Mac OS X, Linux和FreeBSD操作系統(tǒng)。
開(kāi)發(fā)工具
LiteIDE
LiteIDE是一款專(zhuān)門(mén)為Go語(yǔ)言開(kāi)發(fā)的跨平臺(tái)輕量級(jí)集成開(kāi)發(fā)環(huán)境(IDE),由QT編寫(xiě)。
Sublime Text
Sublime Text 3(以下簡(jiǎn)稱(chēng)Sublime)+ GoSublime + gocode + MarGo的組合。
Vim
Vim是從vi發(fā)展出來(lái)的一個(gè)文本編輯器,享有“編輯器之神”的稱(chēng)號(hào)。代碼補(bǔ)全、編譯及錯(cuò)誤跳轉(zhuǎn)等方便編程的功能特別豐富,在程序員中被廣泛使用。
Emacs
Emacs是由GNU開(kāi)源組織開(kāi)發(fā)出來(lái)的一個(gè)文本編輯器,同時(shí)更是一個(gè)整合環(huán)境,曾被人戲稱(chēng)“一個(gè)偽裝成編輯器的操作系統(tǒng)”。
Eclipse
Eclipse也是非常常用的開(kāi)發(fā)利器,可以使用Eclipse來(lái)編寫(xiě)Go程序。
IntelliJ IDEA
熟悉Java的讀者應(yīng)該對(duì)于idea不陌生,idea是通過(guò)一個(gè)插件來(lái)支持go語(yǔ)言的高亮語(yǔ)法,代碼提示和重構(gòu)實(shí)現(xiàn)
問(wèn)答
1.Go的學(xué)習(xí)曲線是怎樣的?
Go不是針對(duì)編程初學(xué)者設(shè)計(jì)的,不過(guò)Go與Java類(lèi)似,對(duì)于Java開(kāi)發(fā)者來(lái)說(shuō),應(yīng)該能夠輕松學(xué)會(huì) Go。
2.Go語(yǔ)言為什么開(kāi)源?
Go之所以開(kāi)源目的是開(kāi)源社區(qū)能夠創(chuàng)建更好的GO程序庫(kù)和工具。