● 本書是作者圍繞軟件工程能力所做的系列培訓的內容匯編。這些內容來源于作者20 多年以來對軟件工程的學習體會和項目實踐,以及對中國工業(yè)界軟件工程師的觀察和教育實踐。
● 全書共8章,第1 章說明了什么是軟件工程能力,闡述了軟件工程能力中的素質要求。第2~8章分別從代碼、文檔、項目管理這三個方面講解了提升軟件工程能力素質的實踐方法。 對于代碼,第2章\"代碼的藝術”對其進行了總體說明,第3 章重點說明了代碼評審,第4章以Mini-spider 為例說明了方法如何運用。 對于文檔,第5章說明了如何寫好項目文檔,第6章說明了做研究的基本方法。對于項目管理,第7章簡要說明了如何做好項目管理,第8章重點說明了如何做好項目溝通。
適讀人群 :軟件工程師和管理者;計算機和軟件方向的在校學生。 ● 百度學院精品課“代碼的藝術”核心內容首次成書,百度技術培訓中心官方指定用書。
● 清華大學、IT名企開設“代碼的藝術”課程及講座,課程獲廣泛贊譽。
● 成為優(yōu)秀軟件工程師三條路徑:
(1)學習-思考-實踐;
(2)知識-方法-精神;
(3)基礎乃治學之根本。
● 具備正確的意識比掌握具體的知識更重要。
● 讀者對象:軟件工程師和管理者;計算機和軟件方向的在校學生。
● 隨書附贈配套視頻,作者在線一對一答疑等增值服務。
本書是筆者圍繞軟件工程能力所做的系列培訓的內容匯編。這些內容來源于筆者20多年以來對軟件工程的學習體會和項目實踐,以及對中國工業(yè)界軟件工程師的觀察和教育實踐。
關于軟件開發(fā)的書已經(jīng)有很多,軟件工程師閱讀最多的書或許是對某種編程語言的深入解讀,或許是對某種架構方法的闡述;蛟S由于意識上的偏差,很多軟件從業(yè)者即使已工作多年,但由于對軟件工程理論相關圖書閱讀較少,因此對軟件研發(fā)的基本理念和原則還是了解得不多。
編寫本書的目的是提升軟件工程師的基本意識。對于一名軟件工程師來說,具備正確的意識比掌握具體的知識更重要。如果具備正確的意識,即使在工作中不記得具體的知識點,也可以在需要的時候進行查閱,而反過來就不是這樣了。
本書對一名軟件工程師應具備的基本意識和所需掌握的基本方法進行了全貌性介紹,同時內容又不會過于理論化和艱深。由于篇幅限制,本書對很多內容只做了入門性介紹,并向希望繼續(xù)深入學習的讀者提供了相關圖書參考建議。
真誠希望讀者能夠從本書開始,更多地去閱讀軟件工程方面的專業(yè)圖書,因為軟件工程師對軟件研發(fā)的學習和深入理解是永無止境的。
本書的目標讀者包括:
(1)軟件工程師和管理者。本書中的多個章節(jié)已經(jīng)是百度內部軟件工程師的必修課內容。筆者也曾多次以“代碼的藝術”為題在多家知名互聯(lián)網(wǎng)企業(yè)做過分享,不僅僅是剛參加工作的軟件工程師給出了較好的反饋,很多資深軟件工程師也反饋良好。
(2)計算機和軟件方向的在校學生。本書介紹的很多方法是筆者在大學時就開始使用的。很多本科生和研究生其實在學校就已經(jīng)開始參加較復雜的軟件研發(fā)項目了,他們可以將本書介紹的方法立刻應用在這些項目實踐中。更早地具備正確的軟件研發(fā)意識,將為一個人后續(xù)的職業(yè)發(fā)展打下良好的基礎。
本書的內容來源于培訓課程材料或演講材料,在章節(jié)編排和內容組織上仍然保持了培訓課程和演講的原貌。每一章都有明確的主題,可以獨立閱讀,而全書的內容又形成了一個完整體系。
全書組織如下(見圖P.1)。
第1章首先說明了什么是軟件工程能力,闡述了軟件工程能力中的素質要求。
第2~8章分別從代碼、文檔和項目管理這三個方面講解了實踐方法。
對于代碼,第2章“代碼的藝術”對其進行了總體說明,第3章重點說明了代碼評審,第4章以Mini-spider為例說明了方法如何運用。
對于文檔,第5章說明了如何寫好項目文檔,第6章說明了做研究的基本方法。
對于項目管理,第7章簡要說明了如何做好項目管理,第8章重點說明了如何做好項目溝通。
章淼,博士,百度智能云資深研發(fā)工程師,BFE開源項目發(fā)起人。
1997年至2006年在清華大學從事互聯(lián)網(wǎng)協(xié)議和網(wǎng)絡體系結構的研究。
2012年加入百度,一直從事網(wǎng)絡基礎架構的研發(fā)工作。同時積極推動百度的代碼質量和工程能力的提升,百度技術培訓中心“金牌講師”,曾任百度代碼規(guī)范委員會主席。
● 第1章 軟件工程能力
1.1 為什么要重視工程能力 / 3
1.2 什么是工程能力 / 5
1.2.1 工程能力的誤區(qū) / 5
1.2.2 工程能力的定義 / 6
1.3 怎樣提升工程能力 / 11
● 第2章 代碼的藝術
2.1 背景和初衷 / 17
2.2 代碼和藝術 / 18
2.2.1 代碼也能成為藝術作品 / 18
2.2.2 軟件工程師和“碼農(nóng)” / 22
2.2.3 來自藝術的啟發(fā) / 24
2.2.4 寫代碼并非易事 / 26
2.3 好代碼和壞代碼 / 28
2.3.1 好代碼的特性 / 28
2.3.2 壞代碼的例子 / 33
2.4 好代碼從哪里來 / 35
2.4.1 好代碼不止于編碼 / 35
2.4.2 需求分析和系統(tǒng)設計 / 36
2.5 如何做好需求分析 / 41
2.5.1 如何描述需求 / 41
2.5.2 對需求分析的誤解 / 43
2.5.3 需求分析的重要性 / 47
2.6 如何做好系統(tǒng)設計 / 47
2.6.1 什么是系統(tǒng)設計 / 48
2.6.2 設計文檔的分類 / 49
2.6.3 什么是系統(tǒng)架構 / 50
2.6.4 系統(tǒng)設計的原則和方法 / 52
2.6.5 重視對外接口 / 56
2.7 如何寫出好代碼 / 59
2.7.1 代碼的溝通價值 / 59
2.7.2 模塊的設計方法 / 64
2.7.3 劃分模塊的方法 / 71
2.7.4 函數(shù)的設計方法 / 75
2.7.5 代碼塊的編寫注意事項 / 85
2.7.6 軟件開發(fā)中的命名 / 89
2.8 如何支持系統(tǒng)運營 / 90
2.8.1 可監(jiān)測性的重要性 / 91
2.8.2 以BFE開源項目為例 / 92
2.9 成為優(yōu)秀軟件工程師的三條路徑 / 93
2.9.1 路徑一:學習—思考—實踐 / 93
2.9.2 路徑二:知識—方法—精神 / 96
2.9.3 路徑三:基礎乃治學之根本 / 98
● 第3章 代碼評審
3.1 代碼評審的常見誤區(qū) / 103
3.2 為什么要做好代碼評審 / 104
3.2.1 代碼評審的重要意義 / 104
3.2.2 沒有做好代碼評審的后果 / 106
3.2.3 為什么要提升代碼質量 / 106
3.2.4 為什么要提升編碼能力 / 108
3.3 如何做好代碼評審 / 108
3.3.1 代碼評審的常見問題 / 109
3.3.2 代碼評審的正確態(tài)度 / 109
3.3.3 代碼評審的推薦步驟 / 111
3.3.4 對壞代碼的簡單判斷 / 112
3.3.5 代碼評審的注意事項 / 113
3.4 如何成為好的代碼評審人 / 116
● 第4章 “代碼的藝術”應用
4.1 需求的分析 / 121
4.1.1 題目說明 / 121
4.1.2 功能分析 / 122
4.2 軟件的架構 / 123
4.2.1 模塊切分 / 123
4.2.2 系統(tǒng)架構 / 128
4.2.3 軟件組裝 / 130
4.2.4 crawler 間的數(shù)據(jù)共用 / 132
4.2.5 數(shù)據(jù)封裝 / 133
4.2.6 crawler 的執(zhí)行邏輯 / 134
4.3 多線程機制 / 135
4.3.1 數(shù)據(jù)互斥訪問 / 136
4.3.2 臨界區(qū)注意事項 / 138
4.3.3 任務的分發(fā) / 141
4.3.4 程序的優(yōu)雅退出 / 143
4.4 其他實現(xiàn)細節(jié) / 146
4.4.1 配置的讀取 / 146
4.4.2 種子信息的讀取 / 147
4.4.3 import 的使用 / 150
4.4.4 異常處理 / 151
4.4.5 構造函數(shù)的使用 / 153
4.4.6 正則表達式的使用 / 154
4.5 延伸思考 / 156
4.5.1 實現(xiàn)對各網(wǎng)站的限速 / 156
4.5.2 從單機擴展到分布式 / 157
● 第5章 項目文檔
5.1 正確認識項目文檔 / 161
5.1.1 項目文檔的重要作用 / 161
5.1.2 項目文檔的常見誤區(qū) / 162
5.1.3 項目文檔的常見問題 / 164
5.1.4 什么時候需要寫項目文檔 / 165
5.1.5 項目文檔是寫給誰的 / 167
5.1.6 項目文檔的基本規(guī)范 / 169
5.2 項目文檔的編寫 / 170
5.2.1 編寫順序 / 170
5.2.2 文檔標題 / 171
5.2.3 段落編寫 / 173
5.2.4 問題劃分 / 176
5.2.5 表述模式 / 177
5.3 項目文檔中的圖片 / 179
5.4 文檔的評審 / 185
5.4.1 文檔評審常見問題 / 185
5.4.2 文檔評審的方法 / 186
5.5 文檔的存放 / 187
5.5.1 文檔存放常見錯誤 / 187
5.5.2 文檔存放的建議 / 188
5.5.3 文檔索引的例子 / 189
5.5.4 存放工具的選擇 / 192
5.6 文檔編寫工具 / 194
5.7 如何提高文檔編寫能力 / 195
● 第6章 做研究
6.1 什么是研究 / 199
6.2 如何做好研究 / 201
6.2.1 發(fā)現(xiàn)問題 / 201
6.2.2 分析問題 / 203
6.2.3 解決問題 / 205
6.3 做好研究的必備素質 / 206
6.3.1 關于做人 / 206
6.3.2 關于做事 / 208
6.3.3 關于做學問 / 209
● 第7章 項目管理
7.1 重視項目管理 / 213
7.2 相關基本概念 / 215
7.3 項目管理的過程和步驟 / 218
7.3.1 項目啟動和規(guī)劃 / 219
7.3.2 項目執(zhí)行和監(jiān)控 / 224
7.3.3 項目總結與回顧 / 227
● 第8章 項目溝通
8.1 項目溝通的重要性 / 233
8.2 項目溝通方式及對比 / 235
8.3 面對面溝通 / 238
8.4 電話溝通 / 239
8.5 會議溝通 / 240
8.6 IM 工具溝通 / 245
8.7 Email 溝通 / 247
● 附錄A 延伸閱讀圖書推薦
軟件工程和編程思想類 / 251
項目管理類 / 252
項目文檔編寫和閱讀類 / 252
產(chǎn)品設計類 / 253