某个函数既返回对象状态值,又修改对象状态。建立2个不同的函数,其中一个负责查询,另一个负责修改。
动机:如果某个函数只是向你提供一个值,没有任何看得到的副作用,那么这是个很有价值的东西。你可以任意调用这个函数,也可能把调用动作搬到函数的其他地方。明确表现出”有副作用”与“无副作用”2种函数之间的差异,是个很好的想法。任何有返回值的函数,都不应该有看得到的副作用。有些程序员甚至将此作为一条必须遵守的规则。
如果你遇到一个“既有返回值又有副作用”的函数,就应该试着将查询动作从修改动作中分割出来。
有一种常见的优化办法是:将查询所得结果缓存于某个字段中,这么一来后续的重复查询就可以大大加快速度。虽然这种做法改变了对象的状态,但这一修改是觉察不到的,因为不论任何查询,你总是获得相同的结果。
做法:1、新建一个查询,令它返回的值与原函数相同。
2、修改原函数,令它调用查询函数,并返回获得的结果。
3、编译、测试。
4、将调用原函数的代码改为调用查询函数;然后,在调用查询函数的那一行之前,加上对原函数的调用。每次修改后,编译并测试。
5、将原函数的返回值改为void,并删掉所有return语句。