zoukankan      html  css  js  c++  java
  • 面向对象设计模式原则06 最少知识原则(LKP)

    最少知识原则(Least Knowledge Principle,LKP)又叫作迪米特法则(Law of Demeter,LoD),它的定义是:只与你的直接朋友交谈,不跟“陌生人”说话。

    其含义是:如果两个软件实体无须直接通信,那么就不应当发生直接的相互调用,可以通过第三方转发该调用。其目的是降低类之间的耦合度,提高模块的相对独立性。

    迪米特法则中的“直接朋友”包含:

    1.当前对象本身

    2.当前对象的成员对象

    3.当前对象所创建的对象

    4.当前对象的方法参数

    5.当前对象的方法返回值

    这些对象同当前对象存在关联、聚合或组合关系,可以直接访问这些对象的方法。

    迪米特法则要求限制软件实体之间通信的宽度和深度,正确使用迪米特法则将有以下两个优点。

    1.降低了类之间的耦合度,提高了模块的相对独立性。

    2.由于亲合度降低,从而提高了类的可复用率和系统的扩展性。

    但是,过度使用迪米特法则会使系统产生大量的中介类,从而增加系统的复杂性,使模块之间的通信效率降低。

    所以,在釆用迪米特法则时需要反复权衡,确保高内聚和低耦合的同时,保证系统的结构清晰。

    从迪米特法则的定义和特点可知,它强调以下两点:

    1.从依赖者的角度来说,只依赖应该依赖的对象。

    2.从被依赖者的角度说,只暴露应该暴露的方法。

    所以,在运用迪米特法则时要注意以下6点:

    1.在类的划分上,应该创建弱耦合的类。类与类之间的耦合越弱,就越有利于实现可复用的目标。

    2.在类的结构设计上,尽量降低类成员的访问权限。

    3.在类的设计上,优先考虑将一个类设置成不变类。

    4.在对其他类的引用上,将引用其他对象的次数降到最低。

    5.不暴露类的属性成员,而应该提供相应的访问器(set 和 get 方法)。

    6.谨慎使用序列化(Serializable)功能。

  • 相关阅读:
    获取到某一方法的调用者的类名、方法名、命名空间(转)
    JQ插件收集
    输出KnownColor枚举颜色值
    SQL 优化之该走索引却不走索引的分析
    oracle日期处理(一)
    ORACLE如何使用DBMS_METADATA.GET_DDL获取DDL语句
    案例分析:ora04031与ora04030错误分析与解决
    分区表、分区索引和全局索引部分总结
    Oracle性能调整指导纲要
    ORACLE常用SQL优化hint语句
  • 原文地址:https://www.cnblogs.com/asenyang/p/11761342.html
Copyright © 2011-2022 走看看