设计模式:迪米特法则(Law of Demeter,LoD)介绍

迪米特法则(Law of Demeter,LoD),也称为最少知识原则(Least Knowledge Principle,LKP),是面向对象设计原则之一,它强调一个对象应该对其他对象有尽可能少的了解,不要和陌生对象直接通信,而是通过中间对象来进行间接通信。简单来说,一个对象应该对其他对象保持最小的了解,只与直接相关的对象进行交互。

迪米特法则的实现原理可以通过以下几点来说明:

  1. 封装对象的行为: 对象应该将自己的行为封装在内部,对外暴露少量的接口来提供服务。这样可以降低对象之间的耦合度,减少对象对其他对象的了解。

  2. 通过中间对象进行通信: 如果一个对象需要与其他对象进行通信,应该通过中间对象来进行间接通信,而不是直接调用陌生对象的方法或访问其属性。

  3. 避免过度依赖: 对象之间的关系应该简单明了,避免过度依赖其他对象的细节,保持对象之间的松耦合关系。

在 Python 中,实现迪米特法则可以通过以下方式:

python 复制代码
# Mediator 类充当中介者,负责协调 person1 和 person2 之间的通信
class Mediator:
    def __init__(self):
        self.person1 = Person1(self)
        self.person2 = Person2(self)

    def notify(self, sender, msg):
        if sender == self.person1:
            self.person2.receive_msg(msg)
        elif sender == self.person2:
            self.person1.receive_msg(msg)

'''
每个同事类(Person1 和 Person2)只知道中介者对象,
不直接与其他同事对象通信,而是通过中介者来进行消息传递
减少对象之间的直接依赖
'''
class Person1:
    def __init__(self, media):
        self.media = media
    def send_msg(self, msg):
        self.media.notify(self, msg)
    def receive_msg(self, msg):
        print(f'person1 receive message: {msg}')

class Person2:
    def __init__(self, media):
        self.media = media
    def send_msg(self, msg):
        self.media.notify(self, msg)
    def receive_msg(self, msg):
        print(f'person2 receive message: {msg}')


mediator = Mediator()

mediator.person1.send_msg('p1_message')

运行结果:

person2 receive message: p1_message

相关推荐
0小豆037 分钟前
【系列开篇】从零构建智能字幕校准系统:一个AI+微服务的完整实战之旅
spring boot·python·nlp·微服务架构·实战项目·spacy·ai算法
周杰伦_Jay1 小时前
【主流开发语言深度对比】Python/Go/Java/JS/Rust/C++评测
开发语言·python·golang
盈电智控1 小时前
体力劳动反而更难被AI取代?物联网科技如何守护最后的劳动阵地
开发语言·人工智能·python
隔壁阿布都1 小时前
Spring Boot中的Optional如何使用
开发语言·spring boot·python
谢景行^顾2 小时前
深度学习--激活函数
人工智能·python·机器学习
三千院本院2 小时前
LlaMA_Factory实战微调Qwen-LLM大模型
人工智能·python·深度学习·llama
wljt2 小时前
Linux 常用命令速查手册(Java开发版)
java·linux·python
WPG大大通2 小时前
AIoT | 软件:Astra MCP边缘算力构建详解
经验分享·笔记·python·硬件架构·代码
波诺波2 小时前
环境管理器
linux·前端·python
诸葛思颖2 小时前
把本地 Python 项目用 Git 进行版本控制并推送到 GitHub
git·python·github