修改軟件的藝術 : 構建易維護代碼的 9條最佳實踐 (Beyond Legacy Code: Nine Practices to Extend the Life (and Value) of Your Software)
戴維·斯科特·伯恩斯坦 (David Scott Bernstein)
- 出版商: 人民郵電
- 出版日期: 2017-10-01
- 定價: $330
- 售價: 8.5 折 $281
- 語言: 簡體中文
- 頁數: 175
- 裝訂: 平裝
- ISBN: 7115467765
- ISBN-13: 9787115467768
-
相關分類:
Engineer self-growth
- 此書翻譯自: Beyond Legacy Code: Nine Practices to Extend the Life (and Value) of Your Software (Paperback) 銷售排行: 👍 2020 年度 簡體中文書 銷售排行 第 10 名
🥉 2020/5 簡體中文書 銷售排行 第 3 名
已絕版
買這商品的人也買了...
-
$420$332 -
$480$408 -
$281程序員修煉之道 :從小工到專家 (The Pragmatic Programmer: From Journeyman to Master)
-
$248測試架構師修煉之道 : 從測試工程師到測試架構師
-
$474$450 -
$234$222 -
$270$257 -
$790$616 -
$650$553 -
$229進化從孤膽極客到高效團隊 (Debugging Teams Better Productivity through Collaboration)
-
$450$356 -
$330$314 -
$1,960Reinforcement Learning: With Open AI, TensorFlow and Keras Using Python
-
$2,200$2,090 -
$580$452 -
$594$564 -
$1,280$1,088 -
$680$578 -
$800$632 -
$720$562 -
$454超大流量分佈式系統架構解決方案:人人都是架構師2.0
-
$454程序員修煉之道:通向務實的最高境界, 2/e
-
$774$735 -
$560$437 -
$520$406
相關主題
商品描述
《修改軟件的藝術 構建易維護代碼的9條最佳實踐》會幫你降低構建與維護軟件的成本。如果你是軟件開發者,將學到一套實踐方法以構建易修改的代碼,因為在應用當中代碼經常需要修改。對於和軟件開發者合作的管理者來說,本書會向你展示為何引入這9個基本的實踐方法,會使你的團隊更加有效地交付軟件而不至於讓軟件演變成遺留代碼。
作者簡介
作者:[美]戴維斯科特伯恩斯坦(David Scott Bernstein)譯者:李滿慶
David Scott Bernstein敏捷教練,曾為IBM、微軟、Yahoo等企業提供敏捷實踐指導。他的公司To Be Agile (tobeagile.com)指導團隊進行測試先行、結對編程以及重構等極限編程實踐。
目錄大綱
第一部分遺留代碼危機
第1章有些事情不對勁2
1.1什麼是遺留代碼3
1.2順流直下4
1.3孤注一擲6
1.4為什麼瀑布模型不管用7
1.4.1食譜與配方7
1.4.2開發和測試分離8
1.5當“流程”變成“體力勞動” 8
1.6堅如磐石的管理9
1.7此處有龍10
1.8評估未知11
1.9一個充滿外行人的產業12
1.10回顧13
第2章逃出混亂14
2.1混亂報告14
2.1 .1成功的15
2.1.2遇到困難的15
2.1.3失敗的(有缺陷的) 15
2.2駁斥斯坦迪什諮詢集團16
2.3項目為何會失敗17
2.4失敗的代價21
2.4.1這裡十幾億,那裡十幾億21
2.4.2不同的研究,同樣的危機22
2.5總結23
第3章聰明人,新想法25
3.1走進敏捷25
3.2小即是好26
3.3實現敏捷27
3.4藝術與技能的平衡28
3.5敏捷跨越鴻溝29
3.6追求技術卓越30
3.7總結31
第二部分延續軟件生命(和價值)的9種實踐方法
第4章9個實踐34
4.1專家知道什麼35
4.2守-破-離36
4.3首要原則37
4.4關於原則38
4.5關於實踐38
4.6原則指導實踐39
4.7未雨綢繆還是隨機應變40
4.8定義軟件中的“好” 40
4.9為什麼是9個實踐42
4.10總結43
第5章實踐1:在問如何做之前先問做什麼、為什麼做、給誰做44
5.1不要說如何44
5.2將“如何”變為“什麼” 45
5.3要有一個產品負責人46
5.4故事描述了做什麼、為什麼做、給誰做48
5.5為驗收測試設立明確標準50
5.6自動化驗收標準50
5.7讓我們付諸實踐51
5.7.1產品負責人的7個策略51
5.7.2編寫出更好用戶故事的7個策略52
5.8總結53
第6章實踐2:小批次構建55
6.1更小的謊言56
6.2學會變通56
6.3控制發布節奏58
6.4越小越好59
6.5分而治之60
6.6更短的反饋迴路62
6.7提高構建速度63
6.8對反饋做出響應64
6.9建立待辦列表65
6.10把用戶故事拆分為任務66
6.11跳出時間盒子思考66
6.12範圍控制67
6.13讓我們付諸實踐69
6.13.1度量軟件開發的7個策略69
6.13.2分割用戶故事的7個策略70
6.14總結71
第7章實踐3:持續集成72
7.1建立項目的心跳73
7.2理解完成、完整完成和完美完成的區別73
7.3實踐持續部署74
7.4自動化構建75
7.5儘早集成,頻繁集成76
7.6邁出第一步76
7.7付諸實踐77
7.7.1構建敏捷設施的7個策略77
7.7.2消除風險的7個策略79
7.8總結80
第8章實踐4:協作81
8.1極限編程82
8.2溝通與協作83
8.3結對編程84
8.3.1結對的好處85
8.3.2如何結對編程86
8.3.3和誰結對87
8.4夥伴編程88
8.5穿刺,群戰,圍攻89
8.5.1穿刺89
8.5.2群戰89
8.5.3圍攻89
8.6在時間盒子中對未知進行調研90
8.7定期代碼審查和回顧會議91
8.8加強學習和知識分享92
8.9誨人不倦且不恥下問92
8.10讓我們付諸實踐93
8.10.1結對編程的7個策略93
8.10.2高效回顧會議的7個策略94
8.11總結95
第9章實踐5:編寫整潔的代碼97
9.1高質量的代碼是內聚的98
9.2高質量的代碼是鬆散耦合的99
9.3高質量的代碼是封裝良好的100
9.4高質量的代碼是自主的102
9.5高質量的代碼是沒有冗餘的104
9.6讓代碼特質指導我們105
9.7今天的代碼質量提高會為將來帶來速度的提升106
9.8讓我們付諸實踐107
9.8.1提高代碼質量的7個策略107
9.8.2編寫可維護代碼的7個策略108
9.9總結109
第10章實踐6:測試先行110
10.1測試的種類111
10.1.1驗收測試=客戶測試111
10.1.2單元測試=開發者測試111
10.1.3其他測試=質量保證測試112
10.2質量保證112
10.2.1測試驅動開發不能取代質量保證113
10.2.2單元測試不是萬能的113
10.3編寫優質測試114
10.3.1這不是測試115
10.3.2以行為作為單元115
10.4 TDD可以提供迅速的反饋116
10.5 TDD可以為重構提供支持116
10.6編寫可測試的代碼117
10.7 TDD也會失敗118
10.8如何將TDD引入團隊119
10.9成為測試感染者119
10.10讓我們付諸實踐120
10.10.1進行優質驗收測試的7個策略120
10.10.2進行優秀單元測試的7個策略121
10.11總結122
第11章實踐7:用測試描述行為123
11.1紅條、綠條、重構124
11.2一個用測試先行來描述行為的實例125
11.2.1編寫測試125
11.2.2存根代碼126
11.2.3實現行為127
11.3引入限制條件128
11.3.1編寫測試和代碼存根129
11.3.2實現行為129
11.4我們創建了什麼130
11.5測試就是標準132
11.6測試需要完整133
11.7讓測試獨一無二134
11.8用測試來覆蓋代碼134
11.9 bug是缺失的測試135
11.10用模擬對象來測試工作流135
11.11建立防護網136
11.12讓我們付諸實踐136
11.12.1使用測試作為標準的7個策略136
11.12.2修復bug的7個策略137
11.13總結139
第12章實踐8:最後實現設計140
12.1可變性的阻礙140
12.2可持續性開發142
12.3編碼與清理143
12.4軟件被閱讀的次數比編寫次數多143
12.5意圖導向編程144
12.6降低圈複雜度145
12.7將創建和使用分離146
12.8演化式設計147
12.9讓我們付諸實踐147
12.9.1進行演化式設計的7個策略148
12.9.2清理代碼的7個策略149
12.10總結150
第13章實踐9:重構遺留代碼151
13.1投資還是藉貸152
13.2變成“鐵公雞” 153
13.3當代碼需要修改時153
13.3.1對已有代碼添加測試154
13.3.2通過重構糟糕代碼來培養良好習慣154
13.3.3推遲那些不可避免的155
13.4重構技巧155
13.4.1圖釘測試155
13.4.2依賴注入156
13.4 .3系統扼殺156
13.4.4抽象分支156
13.5以支持修改為目的重構157
13.6以開閉原則為目的重構157
13.7以提高可修改性為目的重構158
13.8第二次做好158
13.9讓我們付諸實踐159
13.9.1助你正確重構代碼的7個策略159
13.9.2決定何時進行重構的7個策略161
13.10總結162
第14章從遺留代碼中學習163
14.1更好,更快,更廉價164
14.2不在不需要的事情上花錢166
14.3循規蹈矩167
14.4提升整個軟件行業168
14.5超越敏捷169
14.6將理解具象化170
14.7成長的勇氣171
參考文獻174