重构之重新组织函数(Split Temporary Variable)

动机:临时变量有各种不同用途,其中某些用途会很自然的导致临时变量被多次赋值。“循环变量”和“结果收集变量”就是典型的例子:循环变量会随循环的每次运行而改变;   结果收集变量负责将“通过这个函数的运算”而构成的某个值收集起来。

         除了这2种情况,还有很多临时变量保存一段冗长代码的运算结果,以便稍后使用。这种临时变量应该只被赋值一次。如果它们被赋值超过一次,就意味着它们在函数中承担了一个以上的职责。如果临时变量承担多个责任,它就应该被替换为多个临时变量,每个变量只承担一个责任。同一个临时变量承担2件不同的事情,会令代码阅读者糊涂。

1、在待分解临时变量的声明及其第一次被赋值处,修改其名称。如果是结果收集变量就不要分解它。

 2、将新的临时变量声明为const。

 3、以该临时变量的第二次赋值动作为边界,修改此前对该临时变量的所有引用点,让它们引用新的临时变量。

 4、在第二次赋值处,重新声明原先的那个临时变量。

 5、编译、测试。

 6、逐次重复上述过程。每次都在声明处对临时变量改名,并修改下次赋值之前的引用点。

public class SplitTemporaryVariable {

    private double _width,_higth;

    public void doGeometoryCal(){

        double temp = (_higth +_width)*2;
        System.out.println("The perimeter of this is " + temp);

        temp = _higth * _width;
        System.out.println("The area of this is " + temp);


    }

    public void doGeometoryCalAdvanced(){
        double perimeter = (_higth +_width)*2;
        System.out.println("The perimeter of this is " + perimeter);

        double area = _higth * _width;
        System.out.println("The area of this is " + area);
    }

}

 

posted on 2019-12-02 14:56  低调的小郭  阅读(222)  评论(0编辑  收藏  举报