第1章 課程介紹
歡迎你們來到深度講解Go語言的課堂。本課程將從基本語法講起,逐漸深刻,幫助同窗深度理解Go語言面向接口,函數式編程,錯誤處理,測試,並行計算等元素,並帶領你們實現一個分佈式爬蟲的實戰項目。
1-1 課程導讀
1-2 安裝與環境前端
第2章 基礎語法
量,常量,類型,選擇,循環,函數,指針,本章節帶領你們學習一門新語言所需的必備語法知識。讓你們對Go語言有一個初步的認識!
2-1 變量定義
2-2 內建變量類型
2-3 常量與枚舉
2-4 條件語句
2-5 循環
2-6 函數
2-7 指針python
第3章 內建容器
本章節咱們來學習數組,切片,Map和字符串。在Go語言中,咱們通常不直接使用數組,而是使用切片來管理線性表結構,它的語法相似python的list,不過更強大哦。固然,Map和字符串的學習也是必不可少。掌握至此,咱們就能夠寫一些簡單的算法了,刷刷leetcode不在話下,咱們就來試一試。...
3-1 數組
3-2 切片的概念
3-3 切片的操做
3-4 Map
3-5 Map例題
3-6 字符和字符串處理面試
第4章 面向「對象」
Go語言沒有class,只有struct。咱們來看看struct如何使用,Go語言給結構體定義相似方法或者成員函數的作法很是有特點。咱們還將學習Go語言的包的概念,以及如何封裝,如何擴展已有類型等。咱們還將學習GOPATH和Go語言項目的目錄結構,如何從網上下載依賴包等一系列項目相關的知識。咱們將以「樹」的結構和遍歷做爲貫穿本章...
4-1 結構體和方法
4-2 包和封裝
4-3 擴展已有類型
4-4 GOPATH以及目錄結構正則表達式
第5章 面向接口
這一章咱們從duck typing的概念開始學起,還將探討其餘語言中對duck typing的支持,由此引出接口的概念。咱們將深刻理解Go語言接口的內部實現以及使用接口實現組合的模式。
5-1 duck typing的概念
5-2 接口的定義和實現
5-3 接口的值類型
5-4 接口的組合
5-5 經常使用系統接口算法
第6章 函數式編程
在其餘通用語言中,函數式編程是「高級」概念,但對於Go語言卻很是基本。本章咱們將講解函數式編程的概念而且比較其餘語言函數式編程的實現方法。咱們將重點理解閉包。這章中咱們將採用多樣的例題來幫助你們更好的理解閉包,函數做爲一等公民等及其常見概念和應用方法。...
6-1 函數式編程
6-2 函數式編程例一
6-3 函數式編程例二編程
第7章 錯誤處理和資源管理
這將是本課程最「無聊」的一章,但倒是區分出優秀軟件工程師的關鍵能力。Go語言獨特的defer/panic/recover,以及錯誤機制,在社區有着普遍的爭論。咱們來深刻理解Go語言的錯誤處理機制,看看Go語言如何區分錯誤以及異常。最後,咱們實現一個Web應用微型項目,採用商業服務的錯誤處理思路,結合函數式編程,來演示Go語言錯誤...
7-1 defer調用
7-2 錯誤處理概念
7-3 服務器統一出錯處理
7-4 panic和recover
7-5 服務器統一出錯處理2json
第8章 測試與性能調優
Go語言的測試不一樣於其餘如junit,Go語言採用「表格驅動測試」的理念。咱們將學習和體會這樣的理念,並用Go語言的測試支持庫來實踐表格驅動測試,並作代碼覆蓋和性能檢測,經過內建的性能調優工具來優化咱們以前的算法。最後演示了對http服務器的多種粒度的測試。...
8-1 測試
8-2 代碼覆蓋率和性能測試
8-3 使用pprof進行性能調優
8-4 測試http服務器(上)
8-5 測試http服務器(下)
8-6 生成文檔和示例代碼
8-7 測試總結數組
第9章 Goroutine
這一章開始咱們進入併發編程。咱們講解Goroutine,協程的概念,以及背後的Go語言調度器。
9-1 goroutine
9-2 go語言的調度器服務器
第10章 Channel
Channel是Goroutine之間通訊的橋樑,它和函數同樣是一等公民。在介紹完Channel的語法及運行方式後,咱們將採用數個例題來演示Go語言併發編程中最多見的任務極其解決模式。
10-1 channel
10-2 使用Channel等待任務結束
10-3 使用Channel進行樹的遍歷
10-4 用select進行調度
10-5 傳統同步機制閉包
第11章 http及其餘標準庫
這裏咱們簡要介紹一下Go語言中很是重要並且封裝良好的http標準庫,回顧並實現http客戶端和服務器。咱們還介紹了Go語言中其餘的標準庫。
11-1 http標準庫
11-2 其它標準庫
第12章 迷宮的廣度優先搜索
這章咱們將綜合運用學過的知識實現一個廣度優先算法來解迷宮,爲接下來的實戰項目作好技術和算法上的準備。廣度優先算法不只是面試和工做中經常使用的技術,並且實現上相比大部分其它算法更爲複雜,是檢驗是否熟練掌握一門語言的經典例題。讓咱們來試一試吧。...
12-1 迷宮_算法
12-2 迷宮代碼實現
第13章 開始實戰項目
至此爲止,恭喜同窗完成了這門課Go語言部分的學習。接下來咱們來進入實戰項目。本章將介紹項目的具體內容,課題的選擇,技術選型,整體架構,以及實現步驟。
13-1 爬蟲項目介紹
13-2 整體算法
第14章 單任務版爬蟲
在考慮性能以前咱們首先應該考慮正確性。單任務版爬蟲確保咱們可以正確爬取咱們所需的信息。咱們應用了以前練習的廣度優先算法,抽象出Parser和Fetcher,學習正則表達式,成功實現並運行單任務版爬蟲。
14-1 得到初始頁面內容
14-2 正則表達式
14-3 提取城市和url
14-4 單任務版爬蟲的架構
14-5 Engine 與 Parser
14-6 測試CityListParser
14-7 城市解析器
14-8 用戶信息解析器(上)
14-9 用戶信息解析器(下)
14-10 單任務版爬蟲性能
第15章 併發版爬蟲
爲了提高爬蟲性能,咱們抽象出Worker的概念,並添加調度器,實現併發版爬蟲。咱們應用接口的概念,完成了由簡至複雜的多個調度器的實現。同窗能夠在實戰項目中更真實的體會並學習Go語言併發編程的多種模式。
15-1 併發版爬蟲架構
15-2 簡單調度器
15-3 併發調度器
15-4 隊列實現調度器
15-5 重構和總結
15-6 更多城市
15-7 更多用戶與去重
第16章 數據存儲和展現
是時候檢驗咱們項目的成果了。咱們將採用Docker+ElasticSearch來存儲咱們爬取的信息。在簡單瞭解Docker和ElasticSearch後,咱們將使用ElasticSearch的Go語言客戶端將爬取數據寫入。以後咱們使用Go語言的模板引擎迅速實現前端網頁展現。至此,咱們已經能夠嘗試本身喜歡的搜索條件去查看數據啦。...
16-1 ItemSaver的架構
16-2 Docker和ElasticSearch介紹
16-3 Docker的安裝和使用
16-4 ElasticSearch入門
16-5 向ElasticSearch存儲數據
16-6 完整爬蟲的運行與數據存儲
16-7 添加URL與ID
16-8 重構與運行
16-9 標準模板庫介紹
16-10 實現前端展現頁面
16-11 完善前端展現
第17章 分佈式爬蟲
本章在簡要介紹分佈式概念後,將咱們的併發爬蟲改寫成分佈式。咱們在不多改動的狀況下,加入jsonrpc客戶/服務端,實現並部署分佈式爬蟲。最後探討實戰項目的更多改進方案。
17-1 分佈式系統簡介
17-2 分佈式爬蟲架構
17-3 jsonrpc的使用
17-4 ItemSaver服務
17-5 整合ItemSaver服務
17-6 解析器的序列化
17-7 實現爬蟲服務
17-8 完整分佈式爬蟲的運行
17-9 使用鏈接池連接爬蟲集羣
17-10 實戰項目總結
17-11 進一步的工做
第18章 課程總結
感謝同窗們學到這裏,恭喜同窗們給本身的技術棧加上了很是重要的Go語言技能。但願同窗們帶着這門課上學到的知識,更好的參與到項目中去,共同推進Go語言的發展。
18-1 體會Go語言的設計
18-2 課程總結
下載地址:百度網盤下載