Introduce Explaining Variable 引入解释性变量

你有一个复杂的表达式。将该复杂表达式(或其中一部分)的结果放进一个临时变量,以此变量名称来解释表达式用途。

动机

表达式有可能非常复杂而难以阅读。这种情况下,临时变量可以帮助你将表达式分解为比较容易管理的形式。

在条件逻辑中,Introduce Explaining Variable特别有价值:你可以用这项重构将每个条件子句提炼出来,以一个良好命名的临时变量来解释对应条件子句的意义。使用这项重构的另一种情况是,在较长算法中,可以运用临时变量来解释每一步运算的意义。

Introduce Explaining Variable是一个很常见的重构手法,但我得承认,我并不常用它。我几乎总是尽量使用Extract Method来解释一段代码的意义。毕竟临时变量只在它所处的那个函数中才有意义,局限性较大,函数则可以在对象的整个生命中都有用,并且可被其他对象使用。但有时候,当局部变量使 Extract Method难以进行时,我就使用Introduce Explaining Variable。

做法

  • 声明一个final临时变量,将待分解之复杂表达式中的一部分动作的运算结果赋值给它。
  • 将表达式中的“运算结果”这一部分,替换为上述临时变量。
    • 如果被替换的这一部分在代码中重复出现,你可以每次一个,逐一替换。
  • 编译,测试。
  • 重复上述过程,处理表达式的其他部分。

应该在什么时候使用Introduce Explaining Variable呢?答案是:在Extract Method需要花费更大工作量时。如果我要处理的是一个拥有大量局部变量的算法,那么使用Extract Method绝非易事。这种情况下就会使用Introduce Explaining Variable来理清代码,然后冉考虑下一步该怎么办。搞清楚代码逻辑之后,我总是可以运用Replace Temp with Query把中间引入的那些解释性临时变量去掉。况且,如果我最终使用Replace Method with Method Object,那么中间引入的那些解释性临时变量也有其价值。

results matching ""

    No results matching ""