设计模式系列(03):设计原则(二):DIP、ISP、LoD
本文为设计模式系列第3篇,聚焦依赖倒置、接口隔离、迪米特法则三大设计原则,系统梳理定义、实际业务场景、优缺点、最佳实践与常见误区,适合系统学习与团队协作。
目录
- 1. 引言
- 2. 依赖倒置原则(DIP)
- 3. 接口隔离原则(ISP)
- 4. 迪米特法则(LoD)
- 5. 常见误区与反例
- 6. 最佳实践
- 7. 参考资料与延伸阅读
1. 引言
在上一文中,我们介绍了单一职责、开放封闭和里氏替换原则。本文将继续介绍另外三大设计原则:依赖倒置原则(DIP)、接口隔离原则(ISP)、迪米特法则(LoD)。这些原则是构建灵活、可扩展、易维护系统的基础。理解并应用这些原则,可以有效降低系统耦合度,提升代码质量。
2. 依赖倒置原则(DIP)
2.1 定义与背景
依赖倒置原则(Dependency Inversion Principle, DIP)要求高层模块不应该依赖低层模块,二者都应该依赖其抽象。抽象不应该依赖细节,细节应该依赖抽象。通过依赖抽象而非具体实现,可以让系统更加灵活和可扩展。
2.2 应用场景
DIP常用于分层架构中,如业务层与数据层的解耦。依赖注入和IoC容器的广泛应用,也是DIP的体现。插件式架构、可插拔模块等也都依赖于依赖倒置原则来实现灵活扩展。
2.3 代码示例
// 不符合DIP的写法
public class OrderService {private MySQLOrderRepository repository = new MySQLOrderRepository(); // 直接依赖具体实现,违反DIPpublic void createOrder(Order order) {// 业务逻辑System.out.println("创建订单: " + order.getId());repository.save(order);}
}
class MySQLOrderRepository {public void save(Order order) {System.out.println("[MySQL] 保存订单: " + order.getId());}
}
class Order {private String id;public Order(String id) { this.id = id; }public String getId() { return id; }
}
// 使用示例
public class Main {public static void main(String[] args) {OrderService service = new OrderService();service.createOrder(new Order("A1001"));}
}// 符合DIP的写法
// 订单仓储接口,定义抽象
public interface OrderRepository {void save(Order order);
}
// MySQL实现,依赖于抽象
public class MySQLOrderRepository implements OrderRepository {