登入帳戶  | 訂單查詢  | 購物車/收銀台(0) | 在線留言板  | 付款方式  | 聯絡我們  | 運費計算  | 幫助中心 |  加入書簽
會員登入   新用戶註冊
HOME新書上架暢銷書架好書推介特價區會員書架精選月讀2023年度TOP分類閱讀雜誌 香港/國際用戶
最新/最熱/最齊全的簡體書網 品種:超過100萬種書,正品正价,放心網購,悭钱省心 送貨:速遞 / 物流,時效:出貨後2-4日

2024年11月出版新書

2024年10月出版新書

2024年09月出版新書

2024年08月出版新書

2024年07月出版新書

2024年06月出版新書

2024年05月出版新書

2024年04月出版新書

2024年03月出版新書

2024年02月出版新書

2024年01月出版新書

2023年12月出版新書

2023年11月出版新書

2023年10月出版新書

『簡體書』重构 改善既有代码的设计 第2版 平装版

書城自編碼: 3337235
分類: 簡體書→大陸圖書→計算機/網絡程序設計
作 者: [美]马丁·福勒[Martin,Fowler]
國際書號(ISBN): 9787115508652
出版社: 人民邮电出版社
出版日期: 2019-05-01


書度/開本: 16开 釘裝: 平装

售價:NT$ 782

我要買

share:

** 我創建的書架 **
未登入.



新書推薦:
人工智能与大数据:采煤机智能制造
《 人工智能与大数据:采煤机智能制造 》

售價:NT$ 440.0
未来漫游指南:昨日科技与人类未来
《 未来漫游指南:昨日科技与人类未来 》

售價:NT$ 445.0
新民说·逝去的盛景:宋朝商业文明的兴盛与落幕(上下册)
《 新民说·逝去的盛景:宋朝商业文明的兴盛与落幕(上下册) 》

售價:NT$ 790.0
我从何来:自我的心理学探问
《 我从何来:自我的心理学探问 》

售價:NT$ 545.0
失败:1891—1900 清王朝的变革、战争与排外
《 失败:1891—1900 清王朝的变革、战争与排外 》

售價:NT$ 390.0
送你一匹马(“我不求深刻,只求简单。”看三毛如何拒绝内耗,为自己而活)
《 送你一匹马(“我不求深刻,只求简单。”看三毛如何拒绝内耗,为自己而活) 》

售價:NT$ 295.0
秦汉史讲义
《 秦汉史讲义 》

售價:NT$ 690.0
万千心理·我的精神分析之道:复杂的俄狄浦斯及其他议题
《 万千心理·我的精神分析之道:复杂的俄狄浦斯及其他议题 》

售價:NT$ 475.0

建議一齊購買:

+

NT$ 324
《 编程珠玑(第2版·修订版) 》
+

NT$ 573
《 重构 改善既有代码的设计 》
+

NT$ 490
《 构建之法 现代软件工程(第二版) 》
+

NT$ 291
《 编程珠玑(续)(修订版) 》
+

NT$ 407
《 编程之法:面试和算法心得 》
編輯推薦:
1. 软件开发大师的不朽经典
2. 生动阐述重构原理和具体做法 
3. 普通程序员进阶到编程高手必须修炼的秘笈
重构,一言以蔽之,是在不改变外部行为的前提下,有条不紊地改善代码。20 多年前,正是《重构:改善既有代码的设计》第1 版的出版,使重构终于从编程高手们的小圈子走出,成为众多普通程序员日常开发工作中不可或缺的一部分。如今,Martin Fowler 的《重构:改善既有代码的设计》一书已经成为全球有经验的程序员手中的利器,既可用来改善既有代码的设计、提升软件的可维护性,又可用于使既有代码更易理解、焕发出新的活力。
这本备受关注的第2 版在第1 版的基础上做了全面修订,反映了编程领域业已发生的许多变化。第2 版中介绍的重构列表更加内聚,并用JavaScript 语言重写了代码范例。此外,第2 版中还新增了与函数式编程相关的重构范例,旨在教会读者如何在没有类的环境下开展重构。
新版沿袭了第1 版的结构,依次解释什么是重构,为什么要重构,如何通过坏味道识别出需要重构的代码,以及如何在实践中成功实施重构(无论用的是什么编程语言)。
● 理解重构的过程和重构的基本原则;
內容簡介:
本书是经典著作《重构》出版20年后的更新版。书中清晰揭示了重构的过程,解释了重构的原理和实践方式,并给出了何时以及何地应该开始挖掘代码以求改善。书中给出了60多个可行的重构,每个重构都介绍了一种经过验证的代码变换手法的动机和技术。本书提出的重构准则将帮助开发人员一次一小步地修改代码,从而减少了开发过程中的风险。
本书适合软件开发人员、项目管理人员等阅读,也可作为高等院校计算机及相关专业师生的参考读物。
關於作者:
作者简介
马丁福勒(Martin Fowler) 软件开发大师,ThoughtWorks 科学家。他是一位作家、演说者、咨询师。他致力于改善企业级的软件设计,对设计以及支撑设计的工程实践孜孜以求。他在重构、面向对象分析设计、模式、XP 和UML 等领域都有贡献,著有《重构》《分析模式》《领域特定语言》等经典著作。
译者简介
熊节 在IT 行业已经打拼了18年,在金融、零售、政府、电信、制造业等行业的信息化建设方面有着丰富经验,是中国IT业敏捷浪潮的领军人物。熊节拥有利物浦大学MBA学位。
林从羽 ThoughtWorks软件开发工程师,曾服务于国内外多家大型企业,致力于帮助团队更快更好地交付可工作的软件。拥抱敏捷精神,TDD爱好者,纯键盘工作者。
目錄
第 1 章 重构,第 一个示例1
1.1 起点1
1.2 对此起始程序的评价3
1.3 重构的第 一步5
1.4 分解statement 函数6
1.5 进展:大量嵌套函数22
1.6 拆分计算阶段与格式化阶段24
1.7 进展:分离到两个文件(和两个阶段)31
1.8 按类型重组计算过程34
1.9 进展:使用多态计算器来提供数据41
1.10 结语43
第 2 章 重构的原则45
2.1 何谓重构45
2.2 两顶帽子46
2.3 为何重构47
2.4 何时重构50
2.5 重构的挑战55
2.6 重构、架构和YAGNI62
2.7 重构与软件开发过程63
2.8 重构与性能64
2.9 重构起源何处67
2.10 自动化重构68
2.11 延展阅读70
第3 章 代码的坏味道71
3.1 神秘命名(Mysterious Name)72
3.2 重复代码(Duplicated Code)72
3.3 过长函数(Long Function)73
3.4 过长参数列表(Long Parameter List)74
3.5 全局数据(Global Data)74
3.6 可变数据(Mutable Data)75
3.7 发散式变化(Divergent Change)76
3.8 霰弹式修改(Shotgun Surgery)76
3.9 依恋情结(Feature Envy)77
3.10 数据泥团(Data Clumps)78
3.11 基本类型偏执(Primitive Obsession)78
3.12 重复的switch(Repeated Switches)79
3.13 循环语句(Loops)79
3.14 冗赘的元素(Lazy Element)80
3.15 夸夸其谈通用性(Speculative Generality)80
3.16 临时字段(Temporary Field)80
3.17 过长的消息链(Message Chains)81
3.18 中间人(Middle Man)81
3.19 内幕交易(Insider Trading)82
3.20 过大的类(Large Class)82
3.21 异曲同工的类(Alternative Classes with Different Interfaces)83
3.22 纯数据类(Data Class)83
3.23 被拒绝的遗赠(Refused Bequest)83
3.24 注释(Comments)84
第4 章 构筑测试体系85
4.1 自测试代码的价值85
4.2 待测试的示例代码87
4.3 第 一个测试90
4.4 再添加一个测试93
4.5 修改测试夹具95
4.6 探测边界条件96
4.7 测试远不止如此99
第5 章 介绍重构名录101
5.1 重构的记录格式101
5.2 挑选重构的依据102
第6 章 第 一组重构105
6.1 提炼函数(Extract Function)106
6.2 内联函数(Inline Function)115
6.3 提炼变量(Extract Variable)119
6.4 内联变量(Inline Variable)123
6.5 改变函数声明(Change Function Declaration)124
6.6 封装变量(Encapsulate Variable)132
6.7 变量改名(Rename Variable)137
6.8 引入参数对象(Introduce Parameter Object)140
6.9 函数组合成类(Combine Functions into Class)144
6.10 函数组合成变换(Combine Functions into Transform)149
6.11 拆分阶段(Split Phase)154
第7 章 封装161
7.1 封装记录(Encapsulate Record)162
7.2 封装集合(Encapsulate Collection)170
7.3 以对象取代基本类型(Replace Primitive with Object)174
7.4 以查询取代临时变量(Replace Temp with Query)178
7.5 提炼类(Extract Class)182
7.6 内联类(Inline Class)186
7.7 隐藏委托关系(Hide Delegate)189
7.8 移除中间人(Remove Middle Man)192
7.9 替换算法(Substitute Algorithm)195
第8 章 搬移特性197
8.1 搬移函数(Move Function)198
8.2 搬移字段(Move Field)207
8.3 搬移语句到函数(Move Statements into Function)213
8.4 搬移语句到调用者(Move Statements to Callers)217
8.5 以函数调用取代内联代码(Replace Inline Code with Function Call)222
8.6 移动语句(Slide Statements)223
8.7 拆分循环(Split Loop)227
8.8 以管道取代循环(Replace Loop with Pipeline)231
8.9 移除死代码(Remove Dead Code)237
第9 章 重新组织数据239
9.1 拆分变量(Split Variable)240
9.2 字段改名(Rename Field)244
9.3 以查询取代派生变量(Replace Derived Variable with Query)248
9.4 将引用对象改为值对象(Change Reference to Value) 252
9.5 将值对象改为引用对象(Change Value to Reference) 256
第 10 章 简化条件逻辑259
10.1 分解条件表达式(Decompose Conditional)260
10.2 合并条件表达式(Consolidate Conditional Expression)263
10.3 以卫语句取代嵌套条件表达式(Replace Nested Conditional with Guard Clauses)266
10.4 以多态取代条件表达式(Replace Conditional with Polymorphism)272
10.5 引入特例(Introduce Special Case)289
10.6 引入断言(Introduce Assertion)302
第 11 章 重构API305
11.1 将查询函数和修改函数分离(Separate Query from Modifier)306
11.2 函数参数化(Parameterize Function)310
11.3 移除标记参数(Remove Flag Argument)314
11.4 保持对象完整(Preserve Whole Object)319
11.5 以查询取代参数(Replace Parameter with Query)324
11.6 以参数取代查询(Replace Query with Parameter)327
11.7 移除设值函数(Remove Setting Method)331
11.8 以工厂函数取代构造函数(Replace Constructor with Factory Function)334
11.9 以命令取代函数(Replace Function with Command)337
11.10 以函数取代命令(Replace Command with Function)344
第 12 章 处理继承关系349
12.1 函数上移(Pull Up Method)350
12.2 字段上移(Pull Up Field)353
12.3 构造函数本体上移(Pull Up Constructor Body) 355
12.4 函数下移(Push Down Method)359
12.5 字段下移(Push Down Field)361
12.6 以子类取代类型码(Replace Type Code with Subclasses)362
12.7 移除子类(Remove Subclass)369
12.8 提炼超类(Extract Superclass)375
12.9 折叠继承体系(Collapse Hierarchy)380
12.10 以委托取代子类(Replace Subclass with Delegate)381
12.11 以委托取代超类(Replace Superclass with Delegate)399
参考文献 405
索引 409

 

 

書城介紹  | 合作申請 | 索要書目  | 新手入門 | 聯絡方式  | 幫助中心 | 找書說明  | 送貨方式 | 付款方式 台灣用户 | 香港/海外用户
megBook.com.tw
Copyright (C) 2013 - 2024 (香港)大書城有限公司 All Rights Reserved.