0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

接口设计设计模式的六大原则你了解吗?

C语言专家集中营 来源:未知 作者:易水寒 2018-06-10 09:25 次阅读

一. 单一职责原则

Single Responsibility Principle, 简称SRP。

定义

There should never be more than one reason for a class to change应该有且仅有一个原因引起类的变

准则

职责的划分?单一的定义和级别?

应该根据实际业务情况而定。关注变化点。

实际使用时,类很难做到职责单一,但是接口的职责应该尽量单一。

接口设计设计模式的六大原则你了解吗?

二. 里氏替换原则

Liskov Substitution Principle, 简称LSP。

定义

Functions that use pointers or references to base classes must be able to use objects of derived classes without knowing it所有引用基类的地方必须能透明地使用其子类的对象

准则

里氏替换原则为良好的继承定义了一个规范:

子类必须完全实现父类的方法

子类可以有自己的个性(属性和方法)。

覆盖或实现父类的方法时输入参数可以被放大。

覆写或实现父类的方法时输出结果可以被缩小。

注:在类中调用其他类时务必要使用父类或接口,如果不能使用父类或接口,则说明类的设计已经违背了LSP原则。

三. 依赖倒置原则

Dependence Inversion Principle, 简称DIP

定义

High level modules should not depend upon low level modules.Both should depend upon abstractions.Abstractions should not depend upon details.Details should depend upon abstractions.

翻译过来,包含三层含义:

高层模块不应该依赖低层模块,两者都应该依赖其抽象

抽象不应该依赖细节。

细节应该依赖抽象。

精简的定义: 面向接口编程

案例

Test-Driven Development 测试驱动开发是依赖倒置原则的最好体现。

测试驱动开发要求先写测试类,测试通过才写实现类,这就要求你要先想接口定义。

依赖的三种写法:

构造函数传递依赖对象。

Setter方法传递依赖对象。

接口声明依赖对象。

最佳实践:

每个类尽量都有接口或抽象类,或者抽象类和接口两者都具备。变量的表面类型尽量是接口或抽象类。任何类都不应该从具体类派生。尽量不要覆写基类的方法。结合里氏替换原则使用。

四. 接口隔离原则:

接口这里指用interface关键字定义的接口。

定义:

Clients should not be forced to depend upon interfaces that they don’t use.(客户端不应该依赖它不需要的接口)The dependency of one class to anther one should depend on the smallest possible interface.(类间的依赖关系应该建立在最小的接口上)概括:建立单一接口,不要建立臃肿庞大的接口。

通俗来讲:接口尽量细化,同时接口中的方法尽量少。

准则

如何细化?细化到什么程序?

没有统一的标准,应根据业务合理细分,适合业务才是重点。

保证接口的纯结性:

接口要尽量小。接口要高内聚。定制服务。接口的设计是有限度的。

最佳实践:

一个接口只服务于一个子模块或业务逻辑。通过业务逻辑压缩接口中的public方法,接口时常去回顾,尽量让接口达到“满身筋骨肉”,而不是“肥嘟嘟”的一大堆方法。已经被污染了的接口,尽量去修改,若变更的风险较大,则采用适配器模式进行转化处理。了解环境,拒绝盲从。每个项目或产品都有特定的环境因素,不要盲从大师的设计,要根据业务逻辑进行最好的接口设计。

五.迪米特法则

Law of Demeter, LOD。又称最少知识原则(Least Knowledge Principle, LKP)。

定义:

一个对象应该对其他对象保持最少的了解。

准则:

通俗来讲:一个类应该对自己需要耦合或调用的类知道得最少,你(被耦合或调用的类)的内部是如何复杂都和我没有关系,那是你的事情,我就调用你提供的public方法,其他一概不关心。

低耦合要求:

只和朋友交流

朋友类:出现在成员变量、方法的输入输出参数中的类。方法体内部的类不属于朋友类。

朋友间也是有距离的

迪米特法则要求类“羞涩”一点,尽量不要对外公布太多的public方法和非静态的public变量,尽量内敛,多使用private、package-private、protected等访问权限。

是自己的就是自己的

如果一个方法放在本类中,既不增加类间关系,也对本类不产生负面影响,就放置在本类中。

谨慎使用Serializable

六.开闭原则

定义:

Software entities like classes, modules and functions should be open for extension but closed for modifications.一个软件实体如类、模块和函数应该对扩展开放,对修改关闭

准则:

软件实体包括以下几个部分:

项目和软件产品中按照一定的逻辑规则划分的模块。抽象和类。方法。变化的三种类型:

逻辑变化子模块变化可见视图变化

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口设计
    +关注

    关注

    2

    文章

    196

    浏览量

    29670
  • DIP
    DIP
    +关注

    关注

    0

    文章

    236

    浏览量

    29770
  • LSP
    LSP
    +关注

    关注

    0

    文章

    11

    浏览量

    9674

原文标题:接口设计六大原则

文章出处:【微信号:C_Expert,微信公众号:C语言专家集中营】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    软件测试的7大原则漏了几条?

    软件测试报告最需要注意的就是测试思考,而非测试执行。而对软件测试菜鸟来说,初入行,首先要知道软件测试的7条原则了解这些可以让事倍功半。 1测试的不可穷尽原则 是的!任何产品不可能被
    发表于 01-18 09:39

    如何选择IDC服务商十大原则

    如何选择IDC服务商十大原则现在拥有网站的企业或者个人越来越多,对服务器的需求有增无减,如何选择理想的IDC服务商,自然成了他们首要考虑的问题。笔者就此问题,介绍了一些必要的技巧,并概括为选IDC
    发表于 01-21 12:03

    焊接质量不高的六大原因及焊接要领

    一般焊接对焊点的要求是:1)电连接性能良好;2)有一定的机械强度;3)光滑圆润。  下面列出了造成焊接质量不高的六大原因:  1)焊锡用量过多,形成焊点的锡堆积;焊锡过少,不足以包裹焊点。  2
    发表于 11-14 11:57

    Python设计模式六大原则

    Segregation Principle)这个原则的意思是:使用多个隔离的接口,比使用单个接口要好。还是一个降低类之间的耦合度的意思,从这儿我们看出,其实设计模式就是一个软件的设计
    发表于 05-07 18:10

    大原则,让选对继电器

    。但是继电器品类众多,如何挑选优质的继电器成了一个难题。谁才是国民PICK?三大原则,选对继电器在《创造101》中,女团的出道经过了导师和女团创始人的层层把关,综合各方面考虑才筛选出最终的11位成员
    发表于 08-01 20:21

    接口设计的6大原则都知道吗?

    污染了的接口,尽量去修改,若变更的风险较大,则采用适配器模式进行转化处理。了解环境,拒绝盲从。每个项目或产品都有特定的环境因素,不要盲从大师的设计,要根据业务逻辑进行最好的接口设计。五
    发表于 04-20 08:00

    什么设计模式

    目录1.什么设计模式2.设计模式的发展3.设计原则6大原则3.1 开闭原则3.2 里氏转换原则3
    发表于 11-12 06:56

    什么是设计模式?为什么要学习设计模式

    怎么使用设计模式21种设计模式设计模式的遵循的六大原则设计模式之工厂模式.NET CORE微信扫
    发表于 01-19 06:41

    设计模式原则及实现代码的复用

    设计模式六大原则 开闭原则(Open Close Principle) 1988年,勃兰特梅耶(Bertrand Meyer)在他的著作《面向对象软件构造(Object Oriented
    发表于 09-26 15:12 0次下载

    JAVA设计模式六大原则

    单一职责原则:不要存在多于一个导致类变更的原因。通俗的说,即一个类只负责一项职责。 问题由来:类T负责两个不同的职责:职责P1,职责P2。当由于职责P1需求发生改变而需要修改类T时,有可能会导致原本运行正常的职责P2功能发生故障。
    发表于 11-27 11:23 8627次阅读
    JAVA设计<b class='flag-5'>模式</b><b class='flag-5'>六大原则</b>

    一文汇总PCB电路设计的六大原则

    ,可能会出现一些问题,甚至很可能带来严重的电路性能问题。本文主要介绍的是PCB电路设计的六大原则,具体的跟随小编来了解一下。
    发表于 05-04 15:50 5909次阅读
    一文汇总PCB电路设计的<b class='flag-5'>六大原则</b>

    制造业组装线设计必须要纳入的五大原则

    随著全球制造业积极寻求竞争力后,许多业者也开始在运转作过程中设法达到精益生产(Lean Manufacturing)目的。据Automation World报导,厂商在现有组装线设计内可引进五大原则,将可达到避免制程浪费与提升产品质量的目的。
    发表于 07-22 09:39 1684次阅读

    设计模式(1)—什么是设计模式?设计模式六大原则是什么?

    目录1.什么设计模式2.设计模式的发展3.设计原则6大原则3.1 开闭原则3.2 里氏转换原则3
    发表于 11-07 09:51 8次下载
    设计<b class='flag-5'>模式</b>(1)—什么是设计<b class='flag-5'>模式</b>?设计<b class='flag-5'>模式</b>的<b class='flag-5'>六大原则</b>是什么?

    电路布线的七大原则

    电路布线的七大原则  电路布线是电子设计中非常重要的一环,它直接影响着电路的性能和稳定性。因此,在进行电路布线的时候,需要遵循七大原则,这些原则包括电磁兼容性、信号传输、电源噪声、热管理、机械可靠性
    的头像 发表于 10-27 10:26 664次阅读

    分布式存储系统的七大原则之二:区分环境数据与业务数据

    在之前讨论的分布式存储系统七大原则的第一原则中,我们了解了容灾切换和数据备份的差异。现在,我们继续探索第二原则:区分环境数据与业务数据。这一原则
    的头像 发表于 03-11 09:42 130次阅读