重组函数:将部分功能提炼为一个独立的函数,以便之后可被其他函数调用

2024-03-06 06:40

本文主要是介绍重组函数:将部分功能提炼为一个独立的函数,以便之后可被其他函数调用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、这样做动机是什么?
  • 二、具体实现
    • 1.示例
    • 2.开始替换
      • 2.1 检查它们是否只被赋值一次
      • 2.2 替换basePrice中的临时变量
      • 2.3 替换discount中的临时变量
      • 2.4 最终的代码
  • 总结


前言

在程序中,我们会以一个临时变量来保存某一表达式的运算结果,现在我们将这个表达式提炼到一个独立函数,将这个临时变量的所有【被引用】替换为对新函数的调用,新函数可被其他函数使用。
示例:
在这里插入图片描述


一、这样做动机是什么?

临时变量存在的问题:它们是暂时的,而且只能在所属函数内使用。
如果把临时变量替换为一个查询式,那么同一个类中所有的函数都可以获取这个信息,代码可供重复使用。

二、具体实现

1.示例

代码如下(示例):

double getPrice(){int basePrice = quantity * itemPrice;double discount;if(basePrice > 1000) discount = 0.95;else discount = 0.98;return basePricce * discount;
}

现在将basePrice 和discount替换掉。

2.开始替换

2.1 检查它们是否只被赋值一次

将临时变量声明为final进行检测

double getPrice(){final int basePrice = quantity * itemPrice;final double discount;if(basePrice > 1000) discount = 0.95;else discount = 0.98;return basePricce * discount;
}

进行编译,如果没错则表明它们的确只被赋值一次,如果临时变量不知被赋值一次,我们就不应该对其进行重构。下面我们可以放心进行修改了。


2.2 替换basePrice中的临时变量

将临时变量声明为final进行检测

double getPrice(){//替换final int basePrice = basePrice();final double discount;//替换if(basePrice()> 1000) discount = 0.95;else discount = 0.98;//替换return basePrice() * discount;
}
//作为一个函数提炼出来
private int basePrice(){return quantity * itemPrice;
}

2.3 替换discount中的临时变量

double getPrice(){final int basePrice = basePrice();//替换final double discount();//替换return basePricce() * discount();
}
private int basePrice(){return quantity * itemPrice;
}
//作为一个函数提炼出来
private int discount(){//如果上一步没有将临时变量basePrice替换为查询式,将很难提取discountif(basePrice() > 1000) discount = 0.95;else discount = 0.98;
}

2.4 最终的代码

将临时变量声明为final进行检测

//可以看到getPrice()变得非常整洁
double getPrice(){return basePricce() * discount();
}
private int basePrice(){return quantity * itemPrice;
}
private int discount(){if(basePrice() > 1000) discount = 0.95;else discount = 0.98;
}

总结

我们常常使用临时变量保存循环中的累加信息,这种情况下,整个循环都可以被提炼为一个独立的函数,这也使原本的函数可以少掉几行扰人的循环码。
有时候我们可能会用单一的循环累加好几个值,例如这一篇文章所说:
链接: 对list数组的每条数据进行条件判断,拼接之后进行发送或者返回处理
这种情况下应该针对每个累加值重复一遍循环,这样就可以将所有的临时变量都替换为查询式。

这篇关于重组函数:将部分功能提炼为一个独立的函数,以便之后可被其他函数调用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/779148

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl

poj 2594 二分图最大独立集

题意: 求一张图的最大独立集,这题不同的地方在于,间接相邻的点也可以有一条边,所以用floyd来把间接相邻的边也连起来。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <sta

poj 3692 二分图最大独立集

题意: 幼儿园里,有G个女生和B个男生。 他们中间有女生和女生认识,男生男生认识,也有男生和女生认识的。 现在要选出一些人,使得这里面的人都认识,问最多能选多少人。 解析: 反过来建边,将不认识的男生和女生相连,然后求一个二分图的最大独立集就行了。 下图很直观: 点击打开链接 原图: 现图: 、 代码: #pragma comment(

最大流=最小割=最小点权覆盖集=sum-最大点权独立集

二分图最小点覆盖和最大独立集都可以转化为最大匹配求解。 在这个基础上,把每个点赋予一个非负的权值,这两个问题就转化为:二分图最小点权覆盖和二分图最大点权独立集。   二分图最小点权覆盖     从x或者y集合中选取一些点,使这些点覆盖所有的边,并且选出来的点的权值尽可能小。 建模:     原二分图中的边(u,v)替换为容量为INF的有向边(u,v),设立源点s和汇点t

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数