本書首先介紹了Go語(yǔ)言的優(yōu)勢(shì)特性、安裝設(shè)置方法、工程結(jié)構(gòu)、標(biāo)準(zhǔn)命令和工具、語(yǔ)法基礎(chǔ)、數(shù)據(jù)類型以及流程控制方法, 接著闡述了與多進(jìn)程編程和多線程編程有關(guān)的知識(shí), 然后重點(diǎn)介紹了goroutine、channel以及Go提供的傳統(tǒng)同步方法, 之后通過(guò)一個(gè)完整實(shí)例--網(wǎng)絡(luò)爬蟲框架進(jìn)一步闡述Go語(yǔ)言的哲學(xué)和理念, 同時(shí)分享作者在多年編程生涯中的一些見(jiàn)解和感悟。與上一版相比, 本書不僅基于Go 1.8對(duì)上一版進(jìn)行了全面更新, 而且更深入地描繪了Go運(yùn)行時(shí)系統(tǒng)的內(nèi)部機(jī)理, 并且大幅改進(jìn)了示例代碼。
第1章 初識(shí)Go語(yǔ)言 1
1.1 語(yǔ)言特性 1
1.2 安裝和設(shè)置 2
1.3 工程結(jié)構(gòu) 3
1.3.1 工作區(qū) 3
1.3.2 GOPATH 4
1.3.3 源碼文件 5
1.3.4 代碼包 8
1.4 標(biāo)準(zhǔn)命令簡(jiǎn)述 11
1.5 問(wèn)候程序 13
1.6 小結(jié) 14
第2章 語(yǔ)法概覽 15
2.1 基本構(gòu)成要素 15
2.1.1 標(biāo)識(shí)符 15
2.1.2 關(guān)鍵字 16
2.1.3 字面量 17
2.1.4 操作符 17
2.1.5 表達(dá)式 19
2.2 基本類型 20
2.3 高級(jí)類型 22
2.3.1 數(shù)組 23
2.3.2 切片 23
2.3.3 字典 24
2.3.4 函數(shù)和方法 25
2.3.5 接口 28
2.3.6 結(jié)構(gòu)體 29
2.4 流程控制 30
2.4.1 代碼塊和作用域 30
2.4.2 if語(yǔ)句 32
2.4.3 switch語(yǔ)句 32
2.4.4 for語(yǔ)句 34
2.4.5 defer語(yǔ)句 36
2.4.6 panic和recover 38
2.5 聊天機(jī)器人 40
2.6 小結(jié) 44
第3章 并發(fā)編程綜述 45
3.1 并發(fā)編程基礎(chǔ) 45
3.1.1 串行程序與并發(fā)程序 46
3.1.2 并發(fā)程序與并行程序 46
3.1.3 并發(fā)程序與并發(fā)系統(tǒng) 47
3.1.4 并發(fā)程序的不確定性 47
3.1.5 并發(fā)程序內(nèi)部的交互 47
3.2 多進(jìn)程編程 48
3.2.1 進(jìn)程 48
3.2.2 關(guān)于同步 55
3.2.3 管道 60
3.2.4 信號(hào) 65
3.2.5 socket 74
3.3 多線程編程 97
3.3.1 線程 98
3.3.2 線程的同步 107
3.4 多線程與多進(jìn)程 125
3.5 多核時(shí)代的并發(fā)編程 126
3.6 小結(jié) 130
第4章 Go的并發(fā)機(jī)制 131
4.1 原理探究 131
4.1.1 線程實(shí)現(xiàn)模型 132
4.1.2 調(diào)度器 142
4.1.3 更多細(xì)節(jié) 158
4.2 goroutine 160
4.2.1 go語(yǔ)句與goroutine 160
4.2.2 主goroutine的運(yùn)作 166
4.2.3 runtime包與goroutine 166
4.3 channel 169
4.3.1 channel的基本概念 169
4.3.2 單向channel 180
4.3.3 for語(yǔ)句與channel 184
4.3.4 select語(yǔ)句 185
4.3.5 非緩沖的channel 190
4.3.6 time包與channel 192
4.4 實(shí)戰(zhàn)演練:載荷發(fā)生器 198
4.4.1 參數(shù)和結(jié)果 199
4.4.2 基本結(jié)構(gòu) 201
4.4.3 初始化 206
4.4.4 啟動(dòng)和停止 212
4.4.5 調(diào)用器和功能測(cè)試 221
4.5 小結(jié) 231
第5章 同 步 232
5.1 鎖的使用 232
5.1.1 互斥鎖 232
5.1.2 讀寫鎖 236
5.1.3 鎖的完整示例 238
5.2 條件變量 244
5.3 原子操作 247
5.3.1 增或減 247
5.3.2 比較并交換 249
5.3.3 載入 250
5.3.4 存儲(chǔ) 251
5.3.5 交換 251
5.3.6 原子值 252
5.3.7 應(yīng)用于實(shí)際 256
5.4 只會(huì)執(zhí)行一次 257
5.5 WaitGroup 258
5.6 臨時(shí)對(duì)象池 262
5.7 實(shí)戰(zhàn)演練——Concurrent Map 265
5.8 小結(jié) 280
第6章 網(wǎng)絡(luò)爬蟲框架設(shè)計(jì)和實(shí)現(xiàn) 281
6.1 網(wǎng)絡(luò)爬蟲與框架 281
6.2 功能需求和分析 283
6.3 總體設(shè)計(jì) 284
6.4 詳細(xì)設(shè)計(jì) 286
6.4.1 基本數(shù)據(jù)結(jié)構(gòu) 286
6.4.2 接口的設(shè)計(jì) 293
6.5 工具的實(shí)現(xiàn) 309
6.5.1 緩沖器 309
6.5.2 緩沖池 311
6.5.3 多重讀取器 317
6.6 組件的實(shí)現(xiàn) 318
6.6.1 內(nèi)部基礎(chǔ)接口 319
6.6.2 組件注冊(cè)器 321
6.6.3 下載器 323
6.6.4 分析器 325
6.6.5 條目處理管道 328
6.7 調(diào)度器的實(shí)現(xiàn) 329
6.7.1 基本結(jié)構(gòu) 329
6.7.2 初始化 331
6.7.3 啟動(dòng) 333
6.7.4 停止 343
6.7.5 其他方法 344
6.7.6 總結(jié) 345
6.8 一個(gè)簡(jiǎn)單的圖片爬蟲 346
6.8.1 概述 346
6.8.2 命令參數(shù) 346
6.8.3 初始化調(diào)度器 348
6.8.4 監(jiān)控調(diào)度器 354
6.8.5 啟動(dòng)調(diào)度器 364
6.9 擴(kuò)展與思路 365
6.10 本章小結(jié) 368
附錄A Go語(yǔ)言的學(xué)習(xí)資源 369
收起全部↑