现在的位置: 首页 > 综合 > 正文

重构手法45:Separate Query form Modifier (将查询函数和修改函数分离)

2012年09月11日 ⁄ 综合 ⁄ 共 528字 ⁄ 字号 评论关闭

某个函数既返回对象状态值,又修改对象状态。建立2个不同的函数,其中一个负责查询,另一个负责修改。

动机:如果某个函数只是向你提供一个值,没有任何看得到的副作用,那么这是个很有价值的东西。你可以任意调用这个函数,也可能把调用动作搬到函数的其他地方。明确表现出”有副作用”与“无副作用”2种函数之间的差异,是个很好的想法。任何有返回值的函数,都不应该有看得到的副作用。有些程序员甚至将此作为一条必须遵守的规则。

       如果你遇到一个“既有返回值又有副作用”的函数,就应该试着将查询动作从修改动作中分割出来。

       有一种常见的优化办法是:将查询所得结果缓存于某个字段中,这么一来后续的重复查询就可以大大加快速度。虽然这种做法改变了对象的状态,但这一修改是觉察不到的,因为不论任何查询,你总是获得相同的结果。

做法:1、新建一个查询,令它返回的值与原函数相同。

       2、修改原函数,令它调用查询函数,并返回获得的结果。

       3、编译、测试。

       4、将调用原函数的代码改为调用查询函数;然后,在调用查询函数的那一行之前,加上对原函数的调用。每次修改后,编译并测试。

       5、将原函数的返回值改为void,并删掉所有return语句。

 

抱歉!评论已关闭.