设计模式:迪米特法则(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

相关推荐
前进的李工1 天前
LeetCode hot100:234 回文链表:快慢指针巧判回文链表
python·算法·leetcode·链表·快慢指针·回文链表
嫂子的姐夫1 天前
23-MD5+DES+Webpack:考试宝
java·爬虫·python·webpack·node.js·逆向
麦麦鸡腿堡1 天前
Java事件处理机制
java·开发语言·python
谅望者1 天前
数据分析笔记07:Python编程语言介绍
大数据·数据库·笔记·python·数据挖掘·数据分析
Geo_V1 天前
LangChain Memory 使用示例
人工智能·python·chatgpt·langchain·openai·大模型应用·llm 开发
小呀小萝卜儿1 天前
2025-11-15 学习记录--Python-LSTM模型定义(PyTorch)
python·学习·lstm
百锦再1 天前
第15章 并发编程
android·java·开发语言·python·rust·django·go
laufing1 天前
pyinstaller 介绍
python·构建打包
谅望者1 天前
数据分析笔记09:Python条件语循环
笔记·python·数据分析
Auspemak-Derafru1 天前
从U盘损坏中恢复视频文件并修复修改日期的完整解决方案
python