Remove Setting Method(移除设值函数)

动机

如果你为某个字段提供了设值函数,这就暗示这个字段值可以被改变。如果你不希望在对象创建之后此字段还有机会被改变,那就不要为它提供设值函数(同时将该字段设为final)。这样你的意图会更加清晰,并且可以排除其值被修改的可能性——这种可能性往往是非常大的。

如果你保留了间接访问变量的方法,就可能经常有程序员盲目使用它们。这些人甚至会在构造函数中使用设值函数!我猜想他们或许是为了代码的一致性,但却忽视了设值函数往后可能带来的混淆。

做法

  1. 检查设值函数被使用的情况,看他是否只被构造函数调用,或者被构造函数所调用的另一个函数调用。
  2. 修改构造函数,使其直接访问设值函数所针对的那个变量。
  3. 编译,测试。
  4. 移除这个设值函数,将它所针对的字段改为final。
  5. 编译,测试。

范例

class Account {
	private String _id;
	
	Account(String id) {
		SetId(id);
	}
}

以上代码可修改为:

class Account {
	private final String _id;

	Account(String id) {
		_id = id;
	}
}

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