IAd*_*ter 1 language-agnostic refactoring
我现在必须重构一些代码,它基本上是一个方法(大约1000行代码),它做了很多计算并且有很多变量.我不确定如何重构它.代码是否像
...
calculateSth(param1,param2,param3,param4,param5, params6);
calculateSthElse(param1,param2,param3);
...
Run Code Online (Sandbox Code Playgroud)
看起来不错?
我可以引入参数对象,但这些对象只能用作某些方法的参数,所以它看起来像这样
...
calculateSth(calculateSthObject);
calculateSthElse(calculateSthElseObject);
...
Run Code Online (Sandbox Code Playgroud)
或者我可以将所有东西放在一个大物体上并制作它
...
calculateSth(calculateObject);
calculateSthElse(calculateObject);
...
Run Code Online (Sandbox Code Playgroud)
但是在该解决方案中,我必须在方法的开头提取私有方法中所需的所有内容并在最后设置,并且要找出私有方法中使用的值会更加困难.需要大约一半的变量作为输出.
你会怎么做?
PS计算并不简单,所以做的事情就像
calculateObject.setMagicValue4((calculateObject.getMagicValue() * calculateObject.getMagicValue2() / calculateObject.getMagicValue3())
Run Code Online (Sandbox Code Playgroud)
只会让人难以阅读.
我会花费任何必要的时间来确保我理解算法实际上做了什么.然后,我试图找出如何我真的解决这个问题,如果我可以选择,其中可能会涉及到一些类和概念.然后我尝试将这些概念逐一引入现有代码中,确保在我介绍它时为每个概念获得适当的测试覆盖率.
| 归档时间: |
|
| 查看次数: |
117 次 |
| 最近记录: |