Encapsulate Field (封装字段)
Summary : 你的类中存在一个 public 字段。 将它声明为 private ,并提供相应的访问函数。 动机: 面向对象的首要原则之一就是封装,或者成为“数据隐藏”。按此原则,你绝不应该将数据声明为 public ,否则其他对象就有可能访问甚至修改这项数据,而拥有该数据的对象却毫无察觉。于是,数据和行为就被分开了 — 这可不是件好事。 数据声明为 public 被看做是一种不好的做法,因为这样会降低程序的模块化程度。数据和使用该数据的行为如果集中在一起,一旦情况发生变化,代码的修改就会比较简单,因为需要修改的代码都集中于同一块地方,而不是星罗棋布地散落在整个程序中。 Encapsulate Field 是封装过程的第一步。通过这项重构手法,你可以将数据隐藏起来,并提供相应的访问函数。但它毕竟只是第一步。如果一个类除了访问函数外不能提供其他行为,它终究只是一个哑巴类。这样的类并不能享受对象技术带来的好处。而你知道,浪费任何一个对象都是很不好的。实施 Encapsulate Field 之后,我会尝试寻找用到新建访问函数的代码,看看是否可以通过简单的 Move Method 轻快地将它们移到新对象去。 做法: 1. 为 public 字段提供取值 / 设值函数。 2. 找到这个类以外使用该字段的所有地点。如果客户只是读取该字段,就把引用替换为对取值函数的调用