“复杂要人命。它小莫开发者的生命,让产品难以规划、构建和测试。”—— Ray Ozzie
整洁的代码可以帮助开发团队在较低层的抽象层级上达成这一目标。
本节是关于如何保持较高层级——系统层级——上保持整洁。
将系统的构造和使用分开:
例子:酒店在建设时,使用起重机和升降机,而在酒店投入使用时,起重机和升降机就消失无踪,建筑物变得整洁。
软件系统应将启始过程和启始过程之后的运行时逻辑分离开,在启始过程中构建对象,也会存在互相缠结的依赖关系。
public Service getService(){
if (service == null){
service = new MyServiceImpl(...);
}
return service;
}
这是所谓的延迟初始化/赋值,好处:在真正使用对象之前,无需担心这种架空构造。坏处:必须要实现这个构造方法,否则无法编译,即这个对象无法被使用。
将构造和使用分开的方法:
(1)分解main,将系统中的全部构造过程搬迁到main或者main模块中:main函数创建对象,再将对象传递给应用程序,应用程序只管使用,对构造一无所知;
(2)如果应用程序需要负责确定何时创建对象,可以创建抽象工厂,让应用程序控制实体创建的时机