标签分类 热门分类
当前位置:首页 > 程序设计电子书 > 代码设计电子书网盘下载
重构:改善既有代码的设计

重构:改善既有代码的设计 中文版电子书

官方价: 73.3

更 新:

重构:改善既有代码的设计 (pdf、epub、mobi、azw3)下载

下载地址:https://pan.baidu.com/s/17Fx12XsGwQ8J52igubIhV

分享码:yvi7

给大家带来的一篇关于代码设计相关的电子书资源,介绍了关于重构、代码、设计方面的内容,本书是由人民邮电出版社出版,格式根据源资源分为PDF、epub、mobi、azw3其中一种或多种格式,资源大小31 MB,马丁·福勒(Martin Fowler)编写,目前豆瓣、亚马逊、当当、京东等电子书综合评分为:7.2,更多相关的学习资源可以参阅 程序设计电子书、等栏目。

重构:改善既有代码的设计 PDF

1. 开发软件大師的不朽經典 

2. 栩栩如生论述重构基本原理和具体方法 

3. 一般程序猿升阶到编译程序大神务必修练的秘籍 重构,一言以蔽之,是不在更改外界个人行为的前提条件下,井然有序地改善代码。

20 很多年前,更是《重构:改善既有代码的设计》第1 版的出版发行,使重构总算从编译程序高手大神们的小团体摆脱,变成诸多一般程序猿平时开发设计工作上必不可少的一部分。现如今,Martin Fowler 的《重构:改善既有代码的设计》一书早已变成全世界有工作经验的程序猿手上的神器,既能用来改善既有代码的设计、提高手机软件的健壮性,又可用以使既有代码容易了解、容光焕发更新的魅力。 这部深受关心的第2 版在第1 版的基本上干了全方位修定,体现了编译程序行业久已产生的很多转变。第2 版中详细介绍的重构目录更为内聚力,合用JavaScript 言语重写了代码案例。除此之外,第2 版中还增加了与函数式编程有关的重构案例,致力于教會用户怎样在沒有类的自然环境下进行重构。 新版本承袭了第1 版的构造,先后表述什么叫重构,需不需要重构,怎样根据“坏味儿”鉴别出必须重构的代码,及其怎样结合实际取得成功实行重构(不管用的是啥程序语言)。 ● 了解重构的全过程和重构的基本要素; ● 迅速合理地运用各种各样重构技巧,提高程序流程的表达力和健壮性; ● 鉴别代码里能标示出必须重构的地区的“坏味儿”; ● 深层次掌握各种各样重构技巧,每一技巧都包括表述、心理、作法和案例4 个一部分; ● 搭建牢固的检测,以兼容重构工作中的进行; ● 了解重构全过程的衡量选择及其重构存有的挑戰等。 这书汇集了开发软件小区权威专家很多年探求而得到的珍贵工作经验,书中常蕴含的观念和精粹,最该不断吞咽,并且通常可以常读常新。这书是经典书籍《重构》出版发行20多年的新版本。书中清楚表明了重构的全过程,表述了重构的基本原理和实践活动方法,并得出了什么时候及其何处应当刚开始发掘代码其功改善。书中得出了60好几个行得通的重构,每一重构都详细介绍了一种历经认证的代码变换技巧的心理和技术性。这书明确提出的重构规则将协助开发者一次一小步地改动代码,进而降低了开发设计全过程中的风险性。 这书合适手机软件开发者、项目风险管理工作人员等阅读文章,也可做为高等学校电脑及有关技术专业老师学生的参照读本。

目录

  • 第 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 重构、架构和YAGNI 62
  • 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 章 重构API 305
  • 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

上一篇:Spring Cloud微服务架构进阶  下一篇:Python机器学习

展开 +

收起 -

代码设计 相关电子书
代码设计 学习笔记
网友NO.578399

React-intl 实现多语言的示例代码

最近在项目中添加了语言国际化的功能。 语言国际化,也有人说成是语言本地化,其实就是为Web App添加多语言,我们的项目当前包含了中文版和英文版,按理来说『逐字替换』也不是多大事儿,但是,这么Low的做法,有钱途吗? 一开始的时候,我考虑的是传统的为整个项目添加config文件,根据不同的语言和地区,加载不同的config文件,就能够达到界面语言切换的目的。当然,也正是因为这个想法太过于幼稚,所以才被称为『一开始』的想法。语言的国际化不仅仅是将界面上的UI文字翻译成另一种语言,还包括了日期lt;Script引用吧?另外,UI中的文字全部都是使用图片的那个同学,请起立,滚。如果想要在一个React项目中,优雅的import something from somewhere,然后将界面中的文字用首字母大写 / 组件替代,最后通过简单的配置实现语言的国际化,那我们就用React-intl吧。 React 做国际化,我推荐使用 React-intl , 这个库提供了 React 组件和Api两种方式来格式化日期,数字和字符串等。知道这个库了,那让我们开始使用它 组件用法 为了和React 比较融和,我们可以使用组件的方式 1.安装 npm install react-intl --save 2.添加引用 import {IntlProvider, addLocaleData} from 'react-intl'; 3.添加 locale 配置文件 zh-CN.js const zh_CN = { 'intl.hello': "你好", 'intl.name': '我的名……

网友NO.746627

jquery限制输入字数,并提示剩余字数实现代码

!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" html xmlns="http://www.w3.org/1999/xhtml" head meta http-equiv="Content-Type" content="text/html; charset=utf-8" / titlejquery限制输入字数,并提示剩余字数/title script type="text/javascript" src="jquery.js"/script script type="text/javascript" function words_deal() { var curLength=$("#TextArea1").val().length; if(curLength5) { var num=$("#TextArea1").val().substr(0,5); $("#TextArea1").val(num); alert("超过字数限制,多出的字将被截断!" ); } else { $("#textCount").text(5-$("#TextArea1").val().length); } } /script /head body 剩余span id="textCount"5/span个字br / textarea name="textarea" id="TextArea1" cols="45" rows="5" onkeyup="words_deal();" /textarea /body /html ……

网友NO.658709

微信小程序之判断页面滚动方向的示例代码

微信小程序中如果判断页面滚动方向? 解决方案 1.用到微信小程序API 获取页面实际高度 nodesRef.boundingClientRect([callback]) 监听用户滑动页面事件onPageScroll。 2.获取页面实际高度 !--WXML--view id="box" view class="list" wx:for="{{List}}" wx:key="List{{index}}" image mode='aspectFill' class='list_img' src="{{item.imgUrl}}" /image /view/view /* JS */ // 封装函数获取ID为box的元素实际高度 getScrollHeight: function() { wx.createSelectorQuery().select('#box').boundingClientRect((rect) = { this.setData({ scrollHeight: rect.height }) console.log(this.data.scrollHeight) }).exec() }, // 假设数据请求 getDataList: function() { wx.request({ url: 'test.php', //仅为示例,并非真实的接口地址 success: function(res) { // 如果该元素下面的数据是动态获取的,此方法在wx.request请求成功的回调函数中调用 this.getScrollHeight() } }) }, 3.监听用户滑动页面事件 //监听用户滑动页面事件 onPageScroll: function(e) { if (e.scrollTop = 0) { // 滚动到最顶部 e.scrollTop = 0; } else if (e.scrollTop this.data.scrollHeight) { // 滚动到最底部 e.scrollTop = this.data.scrollHeight; } if (e.scrollTop this.data.scrollTop || e.scrollTop = this.data.scrollHeight) { //向下滚动 console.log('向下 ', this.data.scrollHeight) } else { //向上滚动 console.log('向上滚动 ', this.data.scrollHeight) } //给scrollTop重新赋值 this.setData({ scrollTop: e.scrollTop }) }, PS:微……

网友NO.674310

p5.js实现斐波那契螺旋的示例代码

本篇文章主要介绍了p5.js实现斐波那契螺旋的示例代码,分享给大家,也给自己做个笔记 效果如下: 主要方法 translate() rotate() arc() 斐波那契螺旋 斐波那契螺旋线也称“黄金螺旋”,是根据斐波那契数列画出来的螺旋曲线,以斐波那契数为边的正方形中画一个90度的扇形,连起来的弧线就是斐波那契螺旋。 草图 过程分解 一、定义一个空的斐波那契数组: var Fibonacci = []; 二、初始化 默认情况下draw()函数会无限重复绘图, frameRate()函数可以设置每秒重复绘图的次数,就像电影每秒播放的帧数。 function setup(){ createCanvas(windowWidth, windowHeight);//创建一块画板,画板的宽高与浏览器宽高相同 background(255);//设置背景颜色为白色 frameRate(10);//设置每秒10帧} 三、设置斐波那契螺旋的样式 function draw(){ ... stroke(0);//线条颜色为黑色 noFill();//无填充色 strokeWeight(5);//线条宽度为5 translate(windowWidth/2, windowHeight/2);//将坐标系移动到页面中央 ...} 四、开始绘制斐波那契螺旋 function draw(){ ... stroke(0); noFill(); strokeWeight(5); translate(windowWidth/2, windowHeight/2); ... for( var i = 0; i 20; i ++){//绘制20段90度弧线 var a = i = 1 ? 1 : Fibonacci[i-1] + Fibonacci[i-2];//这是条件表达式,如果i等于0或1,那么a等于1;否则等于斐波那契数列前两项的和 Fibonacci.push(a);//将新得到的a加入斐波那契……

champly

champly 发起

资源
14
粉丝
45
喜欢
276
评论
15

    Copyright 2018-2019 xz577.com 码农之家

    版权责任说明