1.保持公共API的接口的不变。
如果随意更改公共接口的类名或者方法名,会造成无法向前兼容。如果需要更改方法名或者类名,则更建议定义一个全新的类。
2.减少依赖关系。像对象实例初始化之类的尽量由外部完成。实例则是通过外部传入
3.保持构造的简单性。
class Car {
private Driver driver;
Car(Context context) {
this.driver = context.getDriver();
}
}
想这种方式的构造则可能看不出神马大问题。但是更好的建议是:
构造改成
Car(Driver driver) {
this.driver = driver;
}
4.减少隐藏依赖或者全局状态
public void reserve() {
DBManager manager = new DBManager();
Listing 5.3 Law of Demeter violation
Listing 5.4 Global state in action
Writing testable code 75
manager.initDatabase();
Reservation r = new Reservation();
r.reserve();
}
在r对象内部可能通过某种方式访问到manager或者访问到manager的内部数据,但是这个时候manager是个全局的状态。如果多个对象同时对manager操作,比如有一个对象做了关闭操作。
更好的是
public void reserve() {
DBManager manager = new DBManager();
manager.initDatabase();
Reservation r = new Reservation (manager);
r.reserve();
}
5.有限使用组合而不是继承。
6.满足以上的条件后,推荐多态(实际上是更推荐接口编程)。
7.尽量保持驱动开发,注意驱动开发是可插入任何开发模型的,它不是独立存在的,不管敏捷还是RUP。
如果随意更改公共接口的类名或者方法名,会造成无法向前兼容。如果需要更改方法名或者类名,则更建议定义一个全新的类。
2.减少依赖关系。像对象实例初始化之类的尽量由外部完成。实例则是通过外部传入
3.保持构造的简单性。
class Car {
private Driver driver;
Car(Context context) {
this.driver = context.getDriver();
}
}
想这种方式的构造则可能看不出神马大问题。但是更好的建议是:
构造改成
Car(Driver driver) {
this.driver = driver;
}
4.减少隐藏依赖或者全局状态
public void reserve() {
DBManager manager = new DBManager();
Listing 5.3 Law of Demeter violation
Listing 5.4 Global state in action
Writing testable code 75
manager.initDatabase();
Reservation r = new Reservation();
r.reserve();
}
在r对象内部可能通过某种方式访问到manager或者访问到manager的内部数据,但是这个时候manager是个全局的状态。如果多个对象同时对manager操作,比如有一个对象做了关闭操作。
更好的是
public void reserve() {
DBManager manager = new DBManager();
manager.initDatabase();
Reservation r = new Reservation (manager);
r.reserve();
}
5.有限使用组合而不是继承。
6.满足以上的条件后,推荐多态(实际上是更推荐接口编程)。
7.尽量保持驱动开发,注意驱动开发是可插入任何开发模型的,它不是独立存在的,不管敏捷还是RUP。