出版時間:2012-8 出版社:人民郵電出版社 作者:許式偉
Tag標簽:無
前言
為什么我們需要一門新語言 編程語言已經非常多,偏性能敏感的編譯型語言有 C、C++、Java、C#、Delphi和Objective-C等,偏快速業(yè)務開發(fā)的動態(tài)解析型語言有 PHP、Python、Perl、Ruby、JavaScript和Lua等,面向特定領域的語言有 Erlang、R和MATLAB等,那么我們?yōu)槭裁葱枰?Go這樣一門新語言呢? 在2000年前的單機時代, C語言是編程之王。隨著機器性能的提升、軟件規(guī)模與復雜度的提高,Java逐步取代了C的位置。盡管看起來 Java已經深獲人心,但 Java編程的體驗并未盡如人意。歷年來的編程語言排行榜(如圖 0-1所示)顯示, Java語言的市場份額在逐步下跌,并趨近于 C語言的水平,顯示了這門語言后勁不足?! D0-1編程語言排行榜① Go語言官方自稱,之所以開發(fā) Go語言,是因為“近 10年來開發(fā)程序之難讓我們有點沮喪”。這一定位暗示了 Go語言希望取代 C和Java的地位,成為最流行的通用開發(fā)語言。 Go希望成為互聯(lián)網時代的 C語言。多數(shù)系統(tǒng)級語言(包括 Java和C#)的根本編程哲學來源于 —————————— ① 據來源: http://www.tiobe.com/index.php/content/paperinfo/tpci/index.html?! ++,將C++的面向對象進一步發(fā)揚光大。但是Go語言的設計者卻有不同的看法,他們認為C++ 真的沒啥好學的,值得學習的是 C語言。C語言經久不衰的根源是它足夠簡單。因此, Go語言也要足夠簡單! 那么,互聯(lián)網時代的 C語言需要考慮哪些關鍵問題呢?首先,并行與分布式支持。多核化和集群化是互聯(lián)網時代的典型特征。作為一個互聯(lián)網時代的C語言,必須要讓這門語言操作多核計算機與計算機集群如同操作單機一樣容易。其次,軟件工程支持。工程規(guī)模不斷擴大是產業(yè)發(fā)展的必然趨勢。單機時代語言可以只關心問題本身的解決,而互聯(lián)網時代的 C語言還需要考慮軟件品質保障和團隊協(xié)作相關的話題。最后,編程哲學的重塑。計算機軟件經歷了數(shù)十年的發(fā)展,形成了面向對象等多種學術流派。什么才是最佳的編程實踐?作為互聯(lián)網時代的 C語言,需要回答這個問題。接下來我們來聊聊 Go語言在這些話題上是如何應對的?! 〔l(fā)與分布式 多核化和集群化是互聯(lián)網時代的典型特征,那語言需要哪些特性來應對這些特征呢?第一個話題是并發(fā)執(zhí)行的“執(zhí)行體”。執(zhí)行體是個抽象的概念,在操作系統(tǒng)層面有多個概念與之對應,比如操作系統(tǒng)自己掌管的進程( process)、進程內的線程( thread)以及進程內的協(xié)程 (coroutine,也叫輕量級線程)。多數(shù)語言在語法層面并不直接支持協(xié)程,而通過庫的方式支持的協(xié)程的功能也并不完整,比如僅僅提供協(xié)程的創(chuàng)建、銷毀與切換等能力。如果在這樣的協(xié)程中調用一個同步 IO操作,比如網絡通信、本地文件讀寫,都會阻塞其他的并發(fā)執(zhí)行協(xié)程,從而無法真正達到協(xié)程本身期望達到的目標。 Go語言在語言級別支持協(xié)程,叫 goroutine。Go語言標準庫提供的所有系統(tǒng)調用( syscall)操作,當然也包括所有同步 IO操作,都會出讓 CPU給其他goroutine,這讓事情變得非常簡單。我們對比一下Java和Go,近距離觀摩下兩者對“執(zhí)行體”的支持?! 榱撕喕覀冊跇永惺褂玫氖?Java標準庫中的線程,而不是協(xié)程,具體代碼如下: public class MyThread implements Runnable { String arg; public MyThread(String a) { arg = a; } public void run() { // ... } public static void main(String[] args) { new Thread(new MyThread(“”test“”)).start(); // ... } } 相同功能的代碼,在 Go語言中是這樣的: func run(arg string) { // ... } func main() { go run(“”test“”) ... } 對比非常鮮明。我相信你已經明白為什么 Go語言會叫 Go語言了:Go語言獻給這個時代最好的禮物,就是加了 go這個關鍵字。當然也有人會說,叫 Go語言是因為它是 Google出的。好吧,這也是個不錯的閑聊主題?! 〉诙€話題是“執(zhí)行體間的通信”。執(zhí)行體間的通信包含幾個方式: ·執(zhí)行體之間的互斥與同步 ·執(zhí)行體之間的消息傳遞 先說·執(zhí)行體之間的互斥與同步·。當執(zhí)行體之間存在共享資源(一般是共享內存)時,為保證內存訪問邏輯的確定性,需要對訪問該共享資源的相關執(zhí)行體進行互斥。當多個執(zhí)行體之間的邏輯存在時序上的依賴時,也往往需要在執(zhí)行體之間進行同步?;コ馀c同步是執(zhí)行體間最基礎的交互方式?! 《鄶?shù)語言在庫層面提供了線程間的互斥與同步支持,那么協(xié)程之間的互斥與同步呢?呃,不好意思,沒有。事實上多數(shù)語言標準庫中連協(xié)程都是看不到的?! ≡僬f·執(zhí)行體之間的消息傳遞·。在并發(fā)編程模型的選擇上,有兩個流派,一個是共享內存模型,一個是消息傳遞模型。多數(shù)傳統(tǒng)語言選擇了前者,少數(shù)語言選擇后者,其中選擇·消息傳遞模型·的最典型代表是 Erlang語言。業(yè)界有專門的術語叫“ Erlang風格的并發(fā)模型”,其主體思想是兩點:一是“輕量級的進程( Erlang中‘進程’這個術語就是我們上面說的‘執(zhí)行體’)”,二是“消息乃進程間通信的唯一方式”。當執(zhí)行體之間需要相互傳遞消息時,通常需要基于一個消息隊列(message queue)或者進程郵箱( process mail box)這樣的設施進行通信?! o語言推薦采用“ Erlang風格的并發(fā)模型”的編程范式,盡管傳統(tǒng)的“共享內存模型”仍然被保留,允許適度地使用。在 Go語言中內置了消息隊列的支持,只不過它叫通道( channel)。兩個goroutine之間可以通過通道來進行交互?! ≤浖こ獭 螜C時代的語言可以只關心問題本身的解決,但是隨著工程規(guī)模的不斷擴大,軟件復雜度的不斷增加,軟件工程也成為語言設計層面要考慮的重要課題。多數(shù)軟件需要一個團隊共同去完成,在團隊協(xié)作的過程中,人們需要建立統(tǒng)一的交互語言來降低溝通的成本。規(guī)范化體現(xiàn)在多個層面,如: ·代碼風格規(guī)范 ·錯誤處理規(guī)范 ·包管理 ·契約規(guī)范(接口) ·單元測試規(guī)范 ·功能開發(fā)的流程規(guī)范 Go語言很可能是第一個將代碼風格強制統(tǒng)一的語言,例如 Go語言要求 public的變量必須以大寫字母開頭,private變量則以小寫字母開頭,這種做法不僅免除了public、private關鍵字,更重要的是統(tǒng)一了命名風格?! ×硗?,Go語言對 { }應該怎么寫進行了強制,比如以下風格是正確的: if expression { ... } 但下面這個寫法就是錯誤的: if expression { ... } 而C和Java語言中則對花括號的位置沒有任何要求。哪種更有利,這個見仁見智。但很顯然的是,所有的 Go代碼的花括號位置肯定是非常統(tǒng)一的。最有意思的其實還是 Go語言首創(chuàng)的錯誤處理規(guī)范: f, err := os.Open(filename) if err != nil { log.Println(“”Open file failed:““, err) return } defer f.Close() ... // 操作已經打開的 f文件 這里有兩個關鍵點。其一是 defer關鍵字。 defer語句的含義是不管程序是否出現(xiàn)異常,均在函數(shù)退出時自動執(zhí)行相關代碼。在上面的例子中,正是因為有了 defer,才使得無論后續(xù)是否會出現(xiàn)異常,都可以確保文件被正確關閉。其二是 Go語言的函數(shù)允許返回多個值。大多數(shù)函數(shù)的最后一個返回值會為 error類型,以在錯誤情況下返回詳細信息。 error類型只是一個系統(tǒng)內置的interface,如下: type error interface { Error() string } 有了error類型,程序出現(xiàn)錯誤的邏輯看起來就相當統(tǒng)一。在Java中,你可能這樣寫代碼來保證資源正確釋放: Connection conn = ...; try { Statement stmt = ...; try { ResultSet rset = ...; try { ... // 正常代碼 } finally { rset.close(); } } finally { stmt.close(); } } finally { conn.close(); } 完成同樣的功能,相應的 Go代碼只需要寫成這樣: conn := ... defer conn.Close() stmt := ... defer stmt.Close() rset := ... defer rset.Close() ... // 正常代碼 對比兩段代碼, Go語言處理錯誤的優(yōu)勢顯而易見。當然,其實 Go語言帶給我們的驚喜還有很多,后續(xù)有機會我們可以就某個更具體的話題詳細展開來談一談。 編程哲學 計算機軟件經歷了數(shù)十年的發(fā)展,形成了多種學術流派,有面向過程編程、面向對象編程、函數(shù)式編程、面向消息編程等,這些思想究竟孰優(yōu)孰劣,眾說紛紜。 C語言是純過程式的,這和它產生的歷史背景有關。 Java語言則是激進的面向對象主義推崇者,典型表現(xiàn)是它不能容忍體系里存在孤立的函數(shù)。而 Go語言沒有去否認任何一方,而是用批判吸收的眼光,將所有編程思想做了一次梳理,融合眾家之長,但時刻警惕特性復雜化,極力維持語言特性的簡潔,力求小而精?! 木幊谭妒降慕嵌葋碚f, Go語言是變革派,而不是改良派。對于C++、Java和C#等語言為代表的面向對象( OO)思想體系,Go語言總體來說持保守態(tài)度,有限吸收。首先,Go語言反對函數(shù)和操作符重載( overload),而C++、Java和C#都允許出現(xiàn)同名函數(shù)或操作符,只要它們的參數(shù)列表不同。雖然重載解決了一小部分面向對象編程( OOP)的問題,但 同樣給這些語言帶來了極大的負擔。而 Go語言有著完全不同的設計哲學,既然函數(shù)重載帶來了負擔,并且這個特性并不對解決任何問題有顯著的價值,那么 Go就不提供它。其次,Go語言支持類、類成員方法、類的組合,但反對繼承,反對虛函數(shù)( virtual function)和虛函數(shù)重載。確切地說, Go也提供了繼承,只不過是采用了組合的文法來提供: type Foo struct { Base ... } func (foo *Foo) Bar() { ... } 再次,Go語言也放棄了構造函數(shù)( constructor)和析構函數(shù)(destructor)。由于Go語言中沒有虛函數(shù),也就沒有 vptr,支持構造函數(shù)和析構函數(shù)就沒有太大的價值。本著“如果一個特性并不對解決任何問題有顯著的價值,那么 Go就不提供它”的原則,構造函數(shù)和析構函數(shù)就這樣被Go語言的作者們干掉了?! ≡诜艞壛舜罅康?OOP特性后,Go語言送上了一份非常棒的禮物:接口( interface)。你可能會說,除了 C這么原始的語言外,還有什么語言沒有接口呢?是的,多數(shù)語言都提供接口,但它們的接口都不同于 Go語言的接口。 Go語言中的接口與其他語言最大的一點區(qū)別是它的非侵入性。在 C++、Java和C#中,為了實現(xiàn)一個接口,你需要從該接口繼承,具體代碼如下: class Foo implements IFoo { // Java文法 ... } class Foo : public IFoo { // C++文法 ... } IFoo* foo = new Foo; 在Go語言中,實現(xiàn)類的時候無需從接口派生,具體代碼如下: type Foo struct { // Go 文法 ... } var foo IFoo = new(Foo) 只要Foo實現(xiàn)了接口IFoo要求的所有方法,就實現(xiàn)了該接口,可以進行賦值。 Go語言的非侵入式接口,看似只是做了很小的文法調整,實則影響深遠。其一,Go語言的標準庫再也不需要繪制類庫的繼承樹圖。你只需要知道這個類實現(xiàn)了哪些 方法,每個方法是啥含義就足夠了。其二,不用再糾結接口需要拆得多細才合理,比如我們實現(xiàn)了 File類,它有下面這些方法: 前言:為什么我們需要一門新語言 Read(buf []byte) (n int, err error) Write(buf []byte) (n int, err error) Seek(off int64, whence int) (pos int64, err error) Close() error 那么,到底是應該定義一個 IFile接口,還是應該定義一系列的 IReader、IWriter、 ISeeker和ICloser接口,然后讓File從它們派生好呢?事實上,脫離了實際的用戶場景,討論這兩個設計哪個更好并無意義。問題在于,實現(xiàn) File類的時候,我怎么知道外部會如何用它呢? 其三,不用為了實現(xiàn)一個接口而專門導入一個包,而目的僅僅是引用其中的某個接口的定義。在Go語言中,只要兩個接口擁有相同的方法列表,那么它們就是等同的,可以相互賦值,如對于以下兩個接口,第一個接口: package one type ReadWriter interface { Read(buf [] byte) (n int, err error) Write(buf [] byte) (n int, err error) } 第二個接口: package two type IStream interface { Write(buf [] byte) (n int, err error) Read(buf [] byte) (n int, err error) } 這里我們定義了兩個接口,一個叫 one.ReadWriter,一個叫 two.IStream,兩者都定義了Read()和Write()方法,只是定義的次序相反。 one.ReadWriter先定義了 Read()再定義 Write(),而two.IStream反之。 在Go語言中,這兩個接口實際上并無區(qū)別,因為: ·任何實現(xiàn)了 one.ReadWriter接口的類,均實現(xiàn)了 two.IStream; ·任何one.ReadWriter接口對象可賦值給 two.IStream,反之亦然; ·在任何地方使用 one.ReadWriter接口,與使用 two.IStream并無差異。所以在Go語言中,為了引用另一個包中的接口而導入這個包的做法是不被推薦的。因為多引用一個外部的包,就意味著更多的耦合。 除了OOP外,近年出現(xiàn)了一些小眾的編程哲學, Go語言對這些思想亦有所吸收。例如, Go語言接受了函數(shù)式編程的一些想法,支持匿名函數(shù)與閉包。再如, Go語言接受了以 Erlang語言為代表的面向消息編程思想,支持 goroutine和通道,并推薦使用消息而不是共享內存來進行并發(fā)編程??傮w來說, Go語言是一個非?,F(xiàn)代化的語言,精小但非常強大?! ⌒〗Y 在十余年的技術生涯中,我接觸過、使用過、喜愛過不同的編程語言,但總體而言, Go語言的出現(xiàn)是最讓我興奮的事情。我個人對未來 10年編程語言排行榜的趨勢判斷如下: □·Java語言的份額繼續(xù)下滑,并最終被 C和Go語言超越; □·C語言將長居編程榜第二的位置,并有望在 Go取代Java前重獲語言榜第一的寶座; □·Go語言最終會取代 Java,居于編程榜之首?! ∮善吲T拼鎯F隊編著的這本書將盡可能展現(xiàn)出 Go語言的迷人魅力。希望本書能夠讓更多人理解這門語言,熱愛這門語言,讓這門優(yōu)秀的語言能夠落到實處,把程序員從以往繁雜的語言細節(jié)中解放出來,集中精力開發(fā)更加優(yōu)秀的系統(tǒng)軟件?! ≡S式偉 2012年3月7日
內容概要
在C語言和Unix操作系統(tǒng)發(fā)布40年后,肯·湯普森等貝爾實驗室原班人馬終于推出了一門全新的編程語言,它就是Go語言。Go語言凝聚了該團隊將近半個世紀對計算機工程的思考成果,被稱為互聯(lián)網時代的C語言。自Go語言第一次發(fā)布以來,七牛云存儲團隊就非常密切地關注這門語言的發(fā)展,并率先在七牛的產品中進行大面積的應用,而開發(fā)效率和系統(tǒng)穩(wěn)定性等客觀數(shù)據也在持續(xù)證明我們選擇Go語言的正確性。因此,我們迫不及待地希望向同行們分享這門語言,大家一起來享受Go語言所帶來的極大樂趣,也一起來促進這門語言的發(fā)展吧! 《Go語言編程》首先概覽了Go語言的誕生和發(fā)展歷程,從面向過程編程特性入手介紹Go語言的基礎用法,讓有一定C語言基礎的讀者可以非常迅速地入門并開始上手用Go語言來解決實際問題,之后介紹了Go語言簡潔卻又無比強大的面向對象編程特性和并發(fā)編程能力,至此讀者已經可以理解為什么Go語言是為互聯(lián)網時代而生的語言。從實用性角度出發(fā),本書還介紹了Go語言標準庫和配套工具的用法,包括安全編程、網絡編程、工程管理工具等。對于希望對Go語言有更深入了解的讀者,我們也特別組織了一系列進階話題,包括語言交互性、鏈接符號、goroutine機理和接口機制等?!禛o語言編程》適合所有層次的開發(fā)者閱讀。
作者簡介
許式偉,七牛云存儲CEO,曾任盛大創(chuàng)新院資深研究員、金山軟件技術總監(jiān)、WPS Office 2005首席架構師。開源愛好者,發(fā)布過WINX、TPL等十余個C++開源項目,擁有超過15年的C/C++開發(fā)經驗。在接觸Go語言后即被其大道至簡、少即是多的設計哲學所傾倒。七牛云存儲是國內第一個吃螃蟹的團隊,核心服務完全采用Go語言實現(xiàn)。呂桂華,七牛云存儲聯(lián)合創(chuàng)始人,曾在金山軟件、盛大游戲等公司擔任架構師和部門經理等職務,在企業(yè)級系統(tǒng)和大型網游平臺領域有較多涉獵。擁有十余年的C/C++大型項目開發(fā)經驗,也曾在Java和.NET平臺上探索多年。同樣被Go語言的魅力所吸引而不可自拔,希望能為推廣這門優(yōu)秀的語言盡自己的綿薄之力。
書籍目錄
目 錄 第1章 初識Go語言 11.1 語言簡史 11.2 語言特性 21.2.1 自動垃圾回收 31.2.2 更豐富的內置類型 41.2.3 函數(shù)多返回值 51.2.4 錯誤處理 61.2.5 匿名函數(shù)和閉包 61.2.6 類型和接口 71.2.7 并發(fā)編程 81.2.8 反射 91.2.9 語言交互性 101.3 第一個Go程序 111.3.1 代碼解讀 111.3.2 編譯環(huán)境準備 121.3.3 編譯程序 121.4 開發(fā)工具選擇 131.5 工程管理 131.6 問題追蹤和調試 181.6.1 打印日志 181.6.2 GDB調試 181.7 如何尋求幫助 181.7.1 郵件列表 191.7.2 網站資源 191.8 小結 19第2章 順序編程 202.1 變量 202.1.1 變量聲明 202.1.2 變量初始化 212.1.3 變量賦值 212.1.4 匿名變量 222.2 常量 222.2.1 字面常量 222.2.2 常量定義 232.2.3 預定義常量 232.2.4 枚舉 242.3 類型 242.3.1 布爾類型 252.3.2 整型 252.3.3 浮點型 272.3.4 復數(shù)類型 282.3.5 字符串 282.3.6 字符類型 302.3.7 數(shù)組 312.3.8 數(shù)組切片 322.3.9 map 362.4 流程控制 382.4.1 條件語句 382.4.2 選擇語句 392.4.3 循環(huán)語句 402.4.4 跳轉語句 412.5 函數(shù) 412.5.1 函數(shù)定義 422.5.2 函數(shù)調用 422.5.3 不定參數(shù) 432.5.4 多返回值 452.5.5 匿名函數(shù)與閉包 452.6 錯誤處理 472.6.1 error接口 472.6.2 defer 482.6.3 panic()和recover() 492.7 完整示例 502.7.1 程序結構 512.7.2 主程序 512.7.3 算法實現(xiàn) 542.7.4 主程序 572.7.5 構建與執(zhí)行 592.8 小結 61第3章 面向對象編程 623.1 類型系統(tǒng) 623.1.1 為類型添加方法 633.1.2 值語義和引用語義 663.1.3 結構體 673.2 初始化 683.3 匿名組合 683.4 可見性 713.5 接口 713.5.1 其他語言的接口 713.5.2 非侵入式接口 733.5.3 接口賦值 743.5.4 接口查詢 763.5.5 類型查詢 783.5.6 接口組合 783.5.7 Any類型 793.6 完整示例 793.6.1 音樂庫 803.6.2 音樂播放 823.6.3 主程序 843.6.4 構建運行 863.6.5 遺留問題 863.7 小結 87第4章 并發(fā)編程 884.1 并發(fā)基礎 884.2 協(xié)程 904.3 goroutine 904.4 并發(fā)通信 914.5 channel 944.5.1 基本語法 954.5.2 select 954.5.3 緩沖機制 964.5.4 超時機制 974.5.5 channel的傳遞 984.5.6 單向channel 984.5.7 關閉channel 994.6 多核并行化 1004.7 出讓時間片 1014.8 同步 1014.8.1 同步鎖 1014.8.2 全局唯一性操作 1024.9 完整示例 1034.9.1 簡單IPC框架 1054.9.2 中央服務器 1084.9.3 主程序 1134.9.4 運行程序 1164.10 小結 117第5章 網絡編程 1185.1 Socket編程 1185.1.1 Dial()函數(shù) 1185.1.2 ICMP示例程序 1195.1.3 TCP示例程序 1215.1.4 更豐富的網絡通信 1225.2 HTTP編程 1245.2.1 HTTP客戶端 1245.2.2 HTTP服務端 1305.3 RPC編程 1325.3.1 Go語言中的RPC支持與處理 1325.3.2 Gob簡介 1345.3.3 設計優(yōu)雅的RPC接口 1345.4 JSON處理 1355.4.1 編碼為JSON格式 1365.4.2 解碼JSON數(shù)據 1375.4.3 解碼未知結構的JSON數(shù)據 1385.4.4 JSON的流式讀寫 1405.5 網站開發(fā) 1405.5.1 最簡單的網站程序 1415.5.2 net/http包簡介 1415.5.3 開發(fā)一個簡單的相冊網站 1425.6 小結 157第6章 安全編程 1586.1 數(shù)據加密 1586.2 數(shù)字簽名 1586.3 數(shù)字證書 1596.4 PKI體系 1596.5 Go語言的哈希函數(shù) 1596.6 加密通信 1606.6.1 加密通信流程 1616.6.2 支持HTTPS的Web服務器 1626.6.3 支持HTTPS的文件服務器 1656.6.4 基于SSL/TLS的ECHO程序 1666.7 小結 169第7章 工程管理 1707.1 Go命令行工具 1707.2 代碼風格 1727.2.1 強制性編碼規(guī)范 1727.2.2 非強制性編碼風格建議 1737.3 遠程import支持 1757.4 工程組織 1757.4.1 GOPATH 1767.4.2 目錄結構 1767.5 文檔管理 1777.6 工程構建 1807.7 跨平臺開發(fā) 1807.7.1 交叉編譯 1817.7.2 Android支持 1827.8 單元測試 1837.9 打包分發(fā) 1847.10 小結 184第8章 開發(fā)工具 1868.1 選擇開發(fā)工具 1868.2 gedit 1878.2.1 語法高亮 1878.2.2 編譯環(huán)境 1878.3 Vim 1888.4 Eclipse 1898.5 Notepad++ 1928.5.1 語法高亮 1928.5.2 編譯環(huán)境 1928.6 LiteIDE 1938.7 小結 195第9章 進階話題 1969.1 反射 1969.1.1 基本概念 1969.1.2 基本用法 1979.1.3 對結構的反射操作 1999.2 語言交互性 1999.2.1 類型映射 2009.2.2 字符串映射 2019.2.3 C程序 2019.2.4 函數(shù)調用 2029.2.5 編譯Cgo 2039.3 鏈接符號 2039.4 goroutine機理 2049.4.1 協(xié)程 2049.4.2 協(xié)程的C語言實現(xiàn) 2059.4.3 協(xié)程庫概述 2059.4.4 任務 2089.4.5 任務調度 2109.4.6 上下文切換 2119.4.7 通信機制 2159.5 接口機理 2169.5.1 類型賦值給接口 2179.5.2 接口查詢 2239.5.3 接口賦值 224附錄A 225
媒體關注與評論
這本書除了完整介紹Go語言特性之外,還深入剖析了語言實現(xiàn)機制。作為服務器軟件開發(fā)者和編程語言愛好者,我強烈推薦此書?!罱埽⒋笪膶W首席架構師《Go語言編程》正是這樣一份猛料,能夠帶領越來越多的人了解Go,學習Go,用Go來實現(xiàn)自己的夢想。——何曉杰,國內知名Android研究者,安居客移動事業(yè)部高級開發(fā)經理《Go語言編程》這本書應當說是作者多年編程經驗的沉淀和反思。本書一方面通過展示和分析大量Go語言代碼,闡明了Go語言基本的使用方式,另一方面通過和C語言代碼進行比較,進一步剖析了語言的內在設計思想,乃至底層實現(xiàn)原理,讓各個層次的讀者都能從書中汲取到大量的知識,使人讀后必有所得?!闲?,Go語言社區(qū)積極推動者,39健康網技術部副總監(jiān)
編輯推薦
國內第一本Go語言編程書原盛大創(chuàng)新院研究員執(zhí)筆Go語言領域技術大牛作品作者Go語言開發(fā)實戰(zhàn)項目幫助您快速入手全新語言
圖書封面
圖書標簽Tags
無
評論、評分、閱讀與下載