Eclipse重构——Move Field

Motivation

如果某个field,在其所驻class之外的另一个class中有更多的函数使用了它,那么可以考虑将这个field移动到另一个class。

Mechanics

1  如果field属性为public,应该先使用EncapsulateField或者Self Encapsulate Field封装该成员。

2  在target class中建立该field,同时应用SelfEncapsulate Field建立set/get函数。

3  在source class中新建引用targetclass对象的成员。将所有对source field的引用,替换为对target class中该field的set/get函数的调用。(要同时处理子类)

删除source field。


Eclipse refactor菜单默认提供了[Move]选项,但是直接Move Field并不会自动更改对该Field的reference。因此实际需要绕一圈。 [Encapsulate] field +  copy + [Inline]

// 重构之前的代码,需要move _interestRate
public class Account …
    private final double _interestRate= 1.0;
    private AccountType _type;
    double interestForAmount_days(double amount, int days) {
        return _interestRate * amount * days / 365;
    }


/1. /对Field "_interestRate",应用[Encapsulate]

publicclassAccount …

privatefinaldouble_interestRate= 1.0;

    private AccountType _type;

    double interestForAmount_days(double amount,int days) {

       return get_interestRate() * amount * days / 365;

    }

    privatedoubleget_interestRate() {

       return_interestRate;

    }

//2. 将"_interestRate" 定义,包括get/set直接复制到目标类。(是直接复制,而不是move 重构)

class AccountType ...

    private final double _interestRate= 1.0;

    private double get_interestRate() {

        return_interestRate;

    }

//3. 将源类中的get/set重新实现为委托给目标类的get/set

public class Account ...

    private final double _interestRate= 1.0;

    double get_interestRate() {

        return _type.get_interestRate();

    }

// 4. 删除源类中的Field " _interestRate" ,应用[Inline]替换get/set为委托给_type

publicclass Account {

    private finaldouble_interestRate = 1.0;

    doubleget_interestRate() {

        return_type.get_interestRate();

}

    private AccountType_type;

    double interestForAmount_days(double amount,int days) {

        return_type.get_interestRate() * amount * days / 365;

    }

 
 
如果有更简单的方法,欢迎分享


上面源码可以在 here 获取。



你可能感兴趣的:(eclipse,重构)