软件设计原则 —— 迪米特原则和合成复用原则

本文介绍迪米特法则(Law of Demeter)和合成复用原则(Composite/Aggregate Reuse Principle),探讨如何通过减少类间的依赖来降低耦合度,使系统更加灵活。同时介绍了这两种设计原则的实际应用案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

迪米特法则(Law of Demeter)又叫作最少知识原则(Least Knowledge Principle 简写LKP),一个类对于其他类知道的越少越好,就是说一个对象应当对其他对象有尽可能少的了解,只和朋友通信,不和陌生人说话。这里的朋友类有以下几种:

  • 当前对象本身
  • 以参数形式传入到当前对象方法中的对象
  • 当前对象实例变量直接引用的对象
  • 当前实例变量如果是一个聚集,则聚集中的元素也是朋友
  • 当前对象所创建的对象

 

迪米特法则的应用的模式有门面模式和(中介者模式),它的初衷在于降低类之间的耦合。由于每个类尽量减少对其他类的依赖,因此,很容易使得系统的功能模块功能独立,相互之间不存在(或很少有)依赖关系。迪米特法则不希望类之间建立直接的联系。如果真的有需要建立联系,也希望能通过它的友元类来转达。因此,应用迪米特法则有可能造成的一个后果就是:系统中存在大量的中介类,这些类之所以存在完全是为了传递类之间的相互调用关系——这在一定程度上增加了系统的复杂度。

合成复用原则(Composite/Aggregate Reuse Principle,CARP)是指尽量使用对象组合(has-a)/聚合(contanis-a)而不是继承关系达到软件复用的目的。可以使系统更加灵活,降低类与类之间的耦合度,一个类的变化对其他类造成的影响相对较少。继承叫作白箱复用,相当于把所有的实现细节暴露给子类。组合/聚合称为黑箱复用,我们是无法获取到类以外的对象的实现细节的。实际上我们我们最常用的就是合成复用原则了,比如下面的代码:

public class UserServiceImpl implements UserService {
    @Autowire
    private UserDao userDao;
}

一般情况下,我们的项目中会大量的用到这两个原则,只是用的时候我们可能没想到这两个原则罢了。软件设计原则是设计模式的基础,设计模式都是在设计原则的基础上总结出来的模式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值