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

重构手法49:Replace Parameter with Methods (以函数取代参数)

2012年05月08日 ⁄ 综合 ⁄ 共 784字 ⁄ 字号 评论关闭

对象调用某个函数,并将所得结果作为参数,传递给另一个函数。而接受该参数的函数本身也能够调用前一个函数。让参数接受者去除该项参数,并直接调用前一个函数。

动机:如果函数可以通过其他途径获得参数值,那么它就不应该通过参数取得该值。过长的参数列会增加程序阅读者的理解难度,因此应该尽可能缩短参数列的长度。

       缩减参数列的办法之一就是:看看参数接受端是否可以通过与调用端相同的计算来取得参数值。如果调用端通过其所属对象内部的另一个函数来计算参数,并在计算过程中未曾引用调用端的其他参数,那么就应该可以将这个计算过程转移到被调用端,从而去除该项参数。如果所调用的函数隶属另一个对象,而该对象拥有调用端所属对象的引用,前面所说的这些也同样适用。

       但是,如果参数值的计算过程依赖于调用端的某个参数,那么就无法去掉被调用端的参数,因为每次调用动作中,该参数值可能不同。另外,如果参数接受端并没有参数发送端对象的引用,而你也不想加上这样一个引用,那么也无法去除参数。

       有时候,参数的存在是为了将来的灵活性。这种情况下仍然可以把这种多余参数拿掉。你应该只在必要关头才添加参数,预先添加的参数很可能并不是你所需要的。对于这条规则,有个例外:如果修改接口会对整个程序造成非常痛苦的结果,那么可以考虑保留前人预先加入的参数。如果真是这样,应该首先判断修改接口究竟会造成多严重的后果,然后考虑是否应该降低给部位之间的依赖,以减少修改接口所造成的影响。稳定的接口确实很好,但是被冻结在一个不良接口上也是一个问题。

做法:1、如果有必要,将参数的计算过程提炼到一个独立函数中。

       2、将函数本体内引用该参数的地方改为对调用新建的函数。

       3、每次替换后,编译、测试。

       4、全部替换完成后,使用Remove Parameter (移除参数)将该参数去掉。

 

抱歉!评论已关闭.