2016书单总结--重构改善既有代码的设计--重新组织函数

本文介绍重构的概念及其在软件开发中的作用,包括改进设计、增强理解、辅助找BUG及提升编程效率。文中阐述了何时进行重构,并详细介绍了几种重构技巧:重新组织函数、内联函数、以查询取代临时变量等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2016书单总结–重构改善既有代码的设计–重新组织函数

重构(refactoring)–在不改变软件可观察行为的前提下改善其内部结构
1. 重构的作用
重构改进软件设计–让所有东西回到应回到的位置
重构使软件更容易理解–让代码变得容易被理解
重构帮助找到BUG–深入理解代码,容易找到BUG
重构提高编程速度–好的设计,可维护性好
2. 什么时候进行重构
添加新功能时进行重构
修补错误时进行重构
复审代码时进行重构
3. 重构的基本技巧–小步前进、频繁测试
4. 重新组织函数
ExtractMethod(提炼函数110)–你有一段代码可以被组织在一起并独立出来
无参数–直接搬运
有参数无改变–直接传递
有参数有改变–用返回值
InlineMethod(内联函数117)–一个函数的本体与名称同样清晰易懂
间接层有价值,但不是所有的间接层都是有价值的
在函数调用点插入函数,替换为对原函数的引用
InlineTemp(内联临时变量119)–你有一个临时变量,只被一个简单的表达式赋值一次,而妨碍了其他重构手法
将所有对该变量的引用替换为对它赋值的那个表达式自身
ReplaceTempWithQuery(以查询取代临时变量120)–你的程序以一个临时变量保存某一表达式的运算结果
将表达式提取到独立函数,以此独立函数替换表达式
IntroduceExplainingVariable(引入解释性变量124)–你有一个复杂的表达式
将复杂表达式的一部分计算结果放入临时变量,以此临时变量名称解释其用途
SplitTemporaryVariable(分解临时变量128)–你程序有一个临时变量被赋值不止超过一次,它既不是循环变量,也不是用于收集计算结果
针对每次赋值,创造一个独立、对应的临时变量
RemoveAssignmentsParameters(移除对参数的赋值131)–代码对一个参数进行赋值
以一个临时变量取代该参数的位置
ReplaceMethodWithMethodObject(以函数对象取代函数135)–你有一个大型函数,其中对局部变量的使用你无法采用ExtractMethod
将函数放入对象,将局部变量提升为对象内字段,然后进行大函数的拆分
SubstituteAlgorithm(替换算法)–你要把某个算法替换为更清晰的算法
将函数本体替换为另一个算法
5. 示例代码位于– https://github.com/undergrowthlinear/2016MyBookSummary.git
重构影片出租店代码在com.undergrowth.refactoring.CustomerBookTest.testStetementOThree有演示
6. 在线书籍版–https://www.refactoring.com/catalog/

#include<iostream> #include<string> #include<sstream> #include<iomanip> using namespace std; class CBook { private: string name, writer; double price; string publish; public: CBook() { price = 0; } CBook(string name, string writer, double price, string publish) :name(name), writer(writer), price(price), publish(publish) {} friend void find(CBook* book, int n, int& max1index, int& max2index); friend istream& operator>>(istream& stream, CBook& book); friend ostream& operator<<(ostream& stream, CBook& book); bool operator>(const CBook& a) { if (price > a.price) { return true; } return false; } }; istream& operator>>(istream& stream, CBook& book) { string line; getline(stream, line); stringstream ss(line); string tmpN, tmpW, tmpP; double tmpPrice; getline(ss, tmpN, ','); getline(ss, tmpW, ','); ss >> tmpPrice; ss.ignore(); getline(ss, tmpP, ','); book.name = tmpN; book.writer = tmpW; book.price = tmpPrice; book.publish = tmpP; return stream; } ostream& operator<<(ostream& stream, CBook& book) { cout << book.name << endl; cout << book.writer << endl; cout <<fixed<<setprecision(2)<< book.price << endl; cout << book.publish << endl; cout << endl; return stream; } void find(CBook* book, int n, int& max1index, int& max2index) { //找最大 CBook tmp; for (int i = 0; i < n; i++) { if (book[i] > tmp) { max1index = i; tmp = book[i]; } } //找次大 CBook tmp2; for (int i = 0; i < n; i++) { if (i == max1index) continue; if (book[i] > tmp2) { max2index = i; tmp2 = book[i]; } } } int main() { int t; cin >> t; while (t--) { int n; cin >> n; CBook* book = new CBook[n]; for (int i = 0; i < n; i++) { cin >> book[i]; } int max1; int max2; find(book, n, max1, max2); cout << book[max1]; cout << book[max2]; delete[]book; } return 0; }id:323】【10分】D. 最贵的书(输入输出重载+友元+引用) 时间限制 1s 内存限制 128MB 题目描述 定义CBook,属性包含书名(string),编者(string)、售价(double),出版社(string)。方法有:重载输入、输出。 定义友元函数find(CBook *book, int n, int &max1index,int &max2index)查找n本书中售价最高、次高的两本书,并通过引用返回其下标。若有相同售价最高、次高的两本书,按输入顺序输出第一本、第二本。 输入n,输入n本书的信息,调用上述友元函数,求价格最高的两本书下标,并按样例格式输出书信息。 输入 测试次数 每组测试数据格式如下: n n行书信息(书名,编者,售价,出版社) 输出 每组测试数据输出两行: 第一行:售价最高的书信息。 第二行:售价次高的书信息。 具体输出格式见样例,售价保留两位小数。书中间以空格分隔。 IO模式 本题IO模式为标准输入/输出(Standard IO),你需要从标准输入流中读入数据,并将答案输出至标准输出流中。 样例查看模式 正常显示 查看格式 输入样例1 <-复制 1 5 python从入门到精通,艾里克.马瑟斯,62.00,人民邮电出版社 Java并发编程实战,盖茨,54.5,机械工业出版社 Effective Java中文版,约书亚.布洛克,94,机械工业出版社 重构 改善既有代码设计,马丁.福勒,122.6,人民邮电出版社 活用数据:驱动业务的数据分析实战,陈哲,61.4,电子工业出版社 输出样例1 重构 改善既有代码设计 马丁.福勒 122.60 人民邮电出版社 Effective Java中文版 约书亚.布洛克 94.00 机械工业出版社 该代码显示部分正确,请在保证源代码基本不变的情况下分析查找哪里出错了
06-06
一直很喜欢重构这本书,但是由于自己记性不太好,书看过之后其中的方法总是记不住,于是想如果有电子版的重构书就好了,工作中遇到重构的问题可以随时打开查阅。在网上搜索了许久,发现重构这本书有英文chm版本的,而中文版的电子书只有扫描的PDF版本,用起来非常不方便。于是萌生想做一本重构工具书的想法,本来打算自己重新重构书的内容再整理归类一下,后来发现原书的目录编排就很适合做工具书,包括坏味道分类,重构手法归类等,都有了一个比较系统的整理。因此,我利用空余时间制作了这样的一本中文的chm版重构,希望对大家有所帮助,也算对中国软件业做出一点小小的贡献。 本书基本上是取自”重构”中文版一书的内容,但格式上参照的是chm英文版的格式,还有一些格式小修改,比如第一章的重构前后代码对比。因为时间匆促,个人能力有限,本书难免存在一些缺漏,如果大家发现有问题,随时可以给我发邮件,我会尽快更新错误的内容。 最后再次感谢几位大师 Martin Fowler、Kent Beck等,还有翻译的侯捷和熊节先生,为我们带来这么精彩的一本书。谢谢。 免责声明:本书仅供个人学习研究之用,不得用于任何商业目的,不得以任何方式修改本作品,基于此产生的法律责任本人不承担任何连带责任。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值