班級規(guī)模及環(huán)境--熱線:4008699035 手機:15921673576( 微信同號) |
每個班級的人數(shù)限3到5人,互動授課, 保障效果,小班授課。 |
上間和地點 |
上部份地點:【上?!客瑵髮W(xué)(滬西)/新城金郡商務(wù)樓(11號線白銀路站)【深圳分部】:電影大廈(地鐵一號線大劇院站)/深圳大學(xué)成教院【北京分部】:北京中山學(xué)院/福鑫大樓【南京分部】:金港大廈(和燕路)【武漢分部】:佳源大廈(高新二路)【成都分部】:領(lǐng)館區(qū)1號(中和大道)【沈陽分部】:沈陽理工大學(xué)/六宅臻品【鄭州分部】:鄭州大學(xué)/錦華大廈【石家莊分部】:河北科技大學(xué)/瑞景大廈 最近開間(周末班/連續(xù)班/晚班):2019年1月26日 |
實驗設(shè)備 |
◆小班教學(xué),教學(xué)效果好 ☆注重質(zhì)量☆邊講邊練 ☆合格學(xué)員免費推薦工作 ★實驗設(shè)備請點擊這兒查看★ |
質(zhì)量保障 |
1、培訓(xùn)過程中,如有部分內(nèi)容理解不透或消化不好,可免費在以后培訓(xùn)班中重聽; 2、培訓(xùn)結(jié)束后,授課老師留給學(xué)員聯(lián)系方式,保障培訓(xùn)效果,免費提供課后技術(shù)支持。 3、培訓(xùn)合格學(xué)員可享受免費推薦就業(yè)機會?!詈细駥W(xué)員免費頒發(fā)相關(guān)工程師等資格證書,提升職業(yè)資質(zhì)。專注高端技術(shù)培訓(xùn)15年,端海學(xué)員的能力得到大家的認(rèn)同,受到用人單位的廣泛贊譽,端海的證書受到廣泛認(rèn)可。 |
部份程大綱 |
|
- 第1章 課程介紹
本課程將從基本語法講起,逐漸深入,幫助同學(xué)深度理解Go語言面向接口,函數(shù)式編程,錯誤處理,測試,并行計算等元素,并帶領(lǐng)大家實現(xiàn)一個分布式爬蟲的實戰(zhàn)項目。
- 1-1 課程導(dǎo)讀 試看
1-2 安裝與環(huán)境
第2章 基礎(chǔ)語法
量,常量,類型,選擇,循環(huán),函數(shù),指針,本章節(jié)帶領(lǐng)大家學(xué)習(xí)一門新語言所需的必備語法知識。讓大家對Go語言有一個初步的認(rèn)識!
- 2-1 變量定義
2-2 內(nèi)建變量類型
2-3 常量與枚舉
2-4 條件語句
2-5 循環(huán)
2-6 函數(shù)
2-7 指針
第3章 內(nèi)建容器
本章節(jié)我們來學(xué)習(xí)數(shù)組,切片,Map和字符串。在Go語言中,我們一般不直接使用數(shù)組,而是使用切片來管理線性表結(jié)構(gòu),它的語法類似python的list,不過更強大哦。當(dāng)然,Map和字符串的學(xué)習(xí)也是必不可少。掌握至此,我們就可以寫一些簡單的算法了,刷刷leetcode不在話下,我們就來試一試。...
- 3-1 數(shù)組
3-2 切片的概念
3-3 切片的操作
3-4 Map
3-5 Map例題
3-6 字符和字符串處理
第4章 面向“對象”
Go語言沒有class,只有struct。我們來看看struct如何使用,Go語言給結(jié)構(gòu)體定義類似方法或者成員函數(shù)的做法非常有特色。我們還將學(xué)習(xí)Go語言的包的概念,以及如何封裝,如何擴展已有類型等。我們還將學(xué)習(xí)GOPATH和Go語言項目的目錄結(jié)構(gòu),如何從網(wǎng)上下載依賴包等一系列項目相關(guān)的知識。我們將以“樹”的結(jié)構(gòu)和遍歷作為貫穿本章...
- 4-1 結(jié)構(gòu)體和方法
4-2 包和封裝
4-3 擴展已有類型
4-4 GOPATH以及目錄結(jié)構(gòu)
第5章 面向接口
這一章我們從duck typing的概念開始學(xué)起,還將探討其他語言中對duck typing的支持,由此引出接口的概念。我們將深入理解Go語言接口的內(nèi)部實現(xiàn)以及使用接口實現(xiàn)組合的模式。
- 5-1 duck typing的概念
5-2 接口的定義和實現(xiàn)
5-3 接口的值類型
5-4 接口的組合
5-5 常用系統(tǒng)接口
第6章 函數(shù)式編程
在其他通用語言中,函數(shù)式編程是“高級”概念,但對于Go語言卻非?;尽1菊挛覀儗⒅v解函數(shù)式編程的概念并且比較其他語言函數(shù)式編程的實現(xiàn)方法。我們將重點理解閉包。這章中我們將采用多樣的例題來幫助大家更好的理解閉包,函數(shù)作為一等公民等及其常見概念和應(yīng)用方法。...
- 6-1 函數(shù)式編程 試看
6-2 函數(shù)式編程例一 試看
6-3 函數(shù)式編程例二
第7章 錯誤處理和資源管理
這將是本課程最“無聊”的一章,但卻是區(qū)分出優(yōu)秀軟件工程師的關(guān)鍵能力。Go語言獨特的defer/panic/recover,以及錯誤機制,在社區(qū)有著廣泛的爭論。我們來深入理解Go語言的錯誤處理機制,看看Go語言如何區(qū)分錯誤以及異常。最后,我們實現(xiàn)一個Web應(yīng)用微型項目,采用商業(yè)服務(wù)的錯誤處理思路,結(jié)合函數(shù)式編程,來演示Go語言錯誤...
- 7-1 defer調(diào)用
7-2 錯誤處理概念
7-3 服務(wù)器統(tǒng)一出錯處理
7-4 panic和recover
7-5 服務(wù)器統(tǒng)一出錯處理2
第8章 測試與性能調(diào)優(yōu)
Go語言的測試不同于其他如junit,Go語言采用“表格驅(qū)動測試”的理念。我們將學(xué)習(xí)和體會這樣的理念,并用Go語言的測試支持庫來實踐表格驅(qū)動測試,并做代碼覆蓋和性能檢測,通過內(nèi)建的性能調(diào)優(yōu)工具來優(yōu)化我們之前的算法。最后演示了對http服務(wù)器的多種粒度的測試。...
- 8-1 測試
8-2 代碼覆蓋率和性能測試
8-3 使用pprof進(jìn)行性能調(diào)優(yōu)
8-4 測試http服務(wù)器(上)
8-5 測試http服務(wù)器(下)
8-6 生成文檔和示例代碼
8-7 測試總結(jié)
第9章 Goroutine
這一章開始我們進(jìn)入并發(fā)編程。我們講解Goroutine,協(xié)程的概念,以及背后的Go語言調(diào)度器。
- 9-1 goroutine
9-2 go語言的調(diào)度器
第10章 Channel
Channel是Goroutine之間通信的橋梁,它和函數(shù)一樣是一等公民。在介紹完Channel的語法及運行方式后,我們將采用數(shù)個例題來演示Go語言并發(fā)編程中最常見的任務(wù)極其解決模式。
- 10-1 channel
10-2 使用Channel等待任務(wù)結(jié)束
10-3 使用Channel進(jìn)行樹的遍歷
10-4 用select進(jìn)行調(diào)度
10-5 傳統(tǒng)同步機制
第11章 http及其他標(biāo)準(zhǔn)庫
這里我們簡要介紹一下Go語言中非常重要而且封裝良好的http標(biāo)準(zhǔn)庫,回顧并實現(xiàn)http客戶端和服務(wù)器。我們還介紹了Go語言中其他的標(biāo)準(zhǔn)庫。
- 11-1 http標(biāo)準(zhǔn)庫
11-2 其它標(biāo)準(zhǔn)庫
第12章 迷宮的廣度優(yōu)先搜索
這章我們將綜合運用學(xué)過的知識實現(xiàn)一個廣度優(yōu)先算法來解迷宮,為接下來的實戰(zhàn)項目做好技術(shù)和算法上的準(zhǔn)備。廣度優(yōu)先算法不僅是面試和工作中常用的技術(shù),而且實現(xiàn)上相比大部分其它算法更為復(fù)雜,是檢驗是否熟練掌握一門語言的經(jīng)典例題。讓我們來試一試吧。...
- 12-1 迷宮_算法
12-2 迷宮代碼實現(xiàn)
第13章 開始實戰(zhàn)項目
至此為止,恭喜同學(xué)完成了這門課Go語言部分的學(xué)習(xí)。接下來我們來進(jìn)入實戰(zhàn)項目。本章將介紹項目的具體內(nèi)容,課題的選擇,技術(shù)選型,總體架構(gòu),以及實現(xiàn)步驟。
- 13-1 爬蟲項目介紹
13-2 總體算法
第14章 單任務(wù)版爬蟲
在考慮性能之前我們首先應(yīng)該考慮正確性。單任務(wù)版爬蟲確保我們能夠正確爬取我們所需的信息。我們應(yīng)用了之前練習(xí)的廣度優(yōu)先算法,抽象出Parser和Fetcher,學(xué)習(xí)正則表達(dá)式,成功實現(xiàn)并運行單任務(wù)版爬蟲。
- 14-1 獲得初始頁面內(nèi)容
14-2 正則表達(dá)式
14-3 提取城市和url
14-4 單任務(wù)版爬蟲的架構(gòu)
14-5 Engine 與 Parser
14-6 測試CityListParser
14-7 城市解析器
14-8 用戶信息解析器(上)
14-9 用戶信息解析器(下)
14-10 單任務(wù)版爬蟲性能
第15章 并發(fā)版爬蟲
為了提升爬蟲性能,我們抽象出Worker的概念,并添加調(diào)度器,實現(xiàn)并發(fā)版爬蟲。我們應(yīng)用接口的概念,完成了由簡至復(fù)雜的多個調(diào)度器的實現(xiàn)。同學(xué)可以在實戰(zhàn)項目中更真實的體會并學(xué)習(xí)Go語言并發(fā)編程的多種模式。
- 15-1 并發(fā)版爬蟲架構(gòu)
15-2 簡單調(diào)度器
15-3 并發(fā)調(diào)度器
15-4 隊列實現(xiàn)調(diào)度器
15-5 重構(gòu)和總結(jié)
15-6 更多城市
15-7 更多用戶與去重
第16章 數(shù)據(jù)存儲和展示
是時候檢驗我們項目的成果了。我們將采用Docker+ElasticSearch來存儲我們爬取的信息。在簡單了解Docker和ElasticSearch后,我們將使用ElasticSearch的Go語言客戶端將爬取數(shù)據(jù)寫入。之后我們使用Go語言的模板引擎迅速實現(xiàn)前端網(wǎng)頁展示。至此,我們已經(jīng)可以嘗試自己喜歡的搜索條件去查看數(shù)據(jù)啦。...
- 16-1 ItemSaver的架構(gòu)
16-2 Docker和ElasticSearch介紹
16-3 Docker的安裝和使用
16-4 ElasticSearch入門
16-5 向ElasticSearch存儲數(shù)據(jù)
16-6 完整爬蟲的運行與數(shù)據(jù)存儲
16-7 添加URL與ID
16-8 重構(gòu)與運行
16-9 標(biāo)準(zhǔn)模板庫介紹
16-10 實現(xiàn)前端展示頁面
16-11 完善前端展示
第17章 分布式爬蟲
本章在簡要介紹分布式概念后,將我們的并發(fā)爬蟲改寫成分布式。我們在很少改動的情況下,加入jsonrpc客戶/服務(wù)端,實現(xiàn)并部署分布式爬蟲。最后探討實戰(zhàn)項目的更多改進(jìn)方案。
- 17-1 分布式系統(tǒng)簡介
17-2 分布式爬蟲架構(gòu)
17-3 jsonrpc的使用
17-4 ItemSaver服務(wù)
17-5 整合ItemSaver服務(wù)
17-6 解析器的序列化
17-7 實現(xiàn)爬蟲服務(wù)
17-8 完整分布式爬蟲的運行
17-9 使用連接池鏈接爬蟲集群
|