您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

软件设计的七大原则

时间:2021-03-01 09:49:40  来源:  作者:

1.开闭原则

⼀个软件实体,如类,模块和函数应该对扩展开放,对修改关闭。所谓的开闭,是对扩展和修改两个⾏为的⼀

个原则。需要强调的是利⽤抽象构建框架,⽤实现扩展细节。

开闭原则是⾯向对象 基础的设计原则,它指导我们如何建立灵活稳定的系统。

2.依赖倒置原则

依赖倒置原则(Dependence Inversion Principle,DIP)是指设计代码结构时,⾼层模块不应该依赖底层模块,⼆者都应该依赖其抽象。抽象不应该依赖细节;细节应该依赖抽象。通过依赖倒置,可以减少类与类之间的耦合性,提⾼系统的稳定性,提⾼代码的 可读性和可维护性,并能够降低修改程序所造成的⻛险。

3.单⼀职责原则

假设我们有⼀个Class负责两个职责,⼀旦发⽣需求变更,修改其中⼀个职责的逻辑代码,有可能会导致另⼀个职责的功能发⽣故障。这样⼀来,这个Class存在两个导致类变更的原因。

在设计的时候将类尽可能拆分,保证⼀个类只负责实现⼀个功能,降低代码的复杂度,在需求变更时,减⼩维护更改的影响范围,,提⾼代码维护性。

4.接⼝隔离原则

接⼝隔离原则(Interface Segregation Principle, ISP)是指⽤多个专⻔的接⼝,⽽不使⽤单⼀的总接⼝,客户端不应该依赖它不需要的接⼝。

接⼝隔离原则符合我们常说的⾼内聚低耦合的设计思想,从⽽使得类具有很好的可读性,可扩展性和可维护性。我们在设计接⼝的时候,要多花时间去思考,要考虑业务模型,包括以后有可能发⽣变更的地⽅还要做⼀些预判。所以,对于抽象,对业务模型的理解 是非常重要的。

5.迪米特法则

迪米特原则(Law of Demeter LoD)是指⼀个对象应该对其他对象保持 少的了解,⼜叫 少知道原则(LeastKnowledge Principle,LKP),尽量降低类与类之间的耦合。 比如物流Service需要查询订单的状态,不⽤在物流Service中增加接⼝,⽽是在订单Service中增加⼀个查询订单状态的接⼝。

6.⾥⽒替换原则

⼀个软件实体如果适⽤⼀个⽗类的话,那⼀定是适⽤于其⼦类,所有引⽤⽗类的地⽅必须能透明地使⽤其⼦类的对 象,⼦类对象能够替换⽗类对象,⽽程序逻辑不变。根据这个理解,我们总结⼀下:引申含义:⼦类可以扩展⽗类的功能,但不能改变⽗类原有的功能。

⾥⽒替换原则是对⼦⽗类关系的描述,即⼦类可以完全替代⽗类,但是⽗类不能替代⼦类。

7.合成复⽤原则

合成复⽤原则(Composite/Aggregate Reuse Principle,CARP)是指尽量使⽤对象组 合(has-a)/聚合(contanis-a),⽽不是继承关系达到软件复⽤的⽬的。可以使系统更加灵 活,降低类与类之间的耦合度,⼀个类的变化对其他类造成的影响相对较少。继承我们叫做⽩箱复⽤,相当于把所有的实现细节暴露给⼦类。组合/聚合也称之为⿊箱复⽤,对类以外的对象是⽆法获取到实现细节的。

总结

设计原则包括: 开闭原则/单⼀原则/依赖倒置原则/接⼝隔离原则/迪米特原则/⾥⽒替换原则/合成复⽤原则

1.对修改关闭,对扩展开放;

2.单⼀职责,⼀个接⼝/类只做⼀件事,降低类和接⼝复杂度,提⾼代码维护性;

3.采⽤接⼝和抽象类来应对变化,通过抽象来定义框架,使⽤实现来扩展细节,应对需求变化;

4.⼦类可以替换⽗类,⽗类不能替换⼦类;

5.组合优于继承,降低类与类之间的耦合;

6.接⼝定义应该尽量细化,尽量避免⼀个接⼝实现多个功能的情况



Tags:软件设计   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
1.开闭原则⼀个软件实体,如类,模块和函数应该对扩展开放,对修改关闭。所谓的开闭,是对扩展和修改两个⾏为的⼀个原则。需要强调的是利⽤抽象构建框架,⽤实现扩展细节。开闭原则是...【详细内容】
2021-03-01  Tags: 软件设计  点击:(237)  评论:(0)  加入收藏
电量:对于移动设备最大的瓶颈就是电量了。因为用户不可能随时携带电源,充电宝。所以必须考虑到电量问题。那就要检查我们工程是不是有后台运行,心跳包发送时间是不是合理。流量...【详细内容】
2019-11-13  Tags: 软件设计  点击:(98)  评论:(0)  加入收藏
电量:对于移动设备最大的瓶颈就是电量了。因为用户不可能随时携带电源,充电宝。所以必须考虑到电量问题。那就要检查我们工程是不是有后台运行,心跳包发送时间是不是合理。流量...【详细内容】
2019-11-13  Tags: 软件设计  点击:(88)  评论:(0)  加入收藏
设计模式可以帮助消除冗余代码。学习如何利用 Java 使用单例模式、工厂模式和观察者模式。-- Bryant Son(作者)如果你是一名正在致力于计算机科学或者相关学科的程序员或者学...【详细内容】
2019-09-03  Tags: 软件设计  点击:(171)  评论:(0)  加入收藏
▌简易百科推荐
摘 要 (OF作品展示)OF之前介绍了用python实现数据可视化、数据分析及一些小项目,但基本都是后端的知识。想要做一个好看的可视化大屏,我们还要学一些前端的知识(vue),网上有很多比...【详细内容】
2021-12-27  项目与数据管理    Tags:Vue   点击:(1)  评论:(0)  加入收藏
程序是如何被执行的  程序是如何被执行的?许多开发者可能也没法回答这个问题,大多数人更注重的是如何编写程序,却不会太注意编写好的程序是如何被运行,这并不是一个好...【详细内容】
2021-12-23  IT学习日记    Tags:程序   点击:(9)  评论:(0)  加入收藏
阅读收获✔️1. 了解单点登录实现原理✔️2. 掌握快速使用xxl-sso接入单点登录功能一、早期的多系统登录解决方案 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器...【详细内容】
2021-12-23  程序yuan    Tags:单点登录(   点击:(8)  评论:(0)  加入收藏
下载Eclipse RCP IDE如果你电脑上还没有安装Eclipse,那么请到这里下载对应版本的软件进行安装。具体的安装步骤就不在这赘述了。创建第一个标准Eclipse RCP应用(总共分为六步)1...【详细内容】
2021-12-22  阿福ChrisYuan    Tags:RCP应用   点击:(7)  评论:(0)  加入收藏
今天想简单聊一聊 Token 的 Value Capture,就是币的价值问题。首先说明啊,这个话题包含的内容非常之光,Token 的经济学设计也可以包含诸多问题,所以几乎不可能把这个问题说的清...【详细内容】
2021-12-21  唐少华TSH    Tags:Token   点击:(9)  评论:(0)  加入收藏
实现效果:假如有10条数据,分组展示,默认在当前页面展示4个,点击换一批,从第5个开始继续展示,到最后一组,再重新返回到第一组 data() { return { qList: [], //处理后...【详细内容】
2021-12-17  Mason程    Tags:VUE   点击:(14)  评论:(0)  加入收藏
什么是性能调优?(what) 为什么需要性能调优?(why) 什么时候需要性能调优?(when) 什么地方需要性能调优?(where) 什么时候来进行性能调优?(who) 怎么样进行性能调优?(How) 硬件配...【详细内容】
2021-12-16  软件测试小p    Tags:性能调优   点击:(19)  评论:(0)  加入收藏
Tasker 是一款适用于 Android 设备的高级自动化应用,它可以通过脚本让重复性的操作自动运行,提高效率。 不知道从哪里听说的抖音 app 会导致 OLED 屏幕烧屏。于是就现学现卖,自...【详细内容】
2021-12-15  ITBang    Tags:抖音防烧屏   点击:(23)  评论:(0)  加入收藏
11 月 23 日,Rust Moderation Team(审核团队)在 GitHub 上发布了辞职公告,即刻生效。根据公告,审核团队集体辞职是为了抗议 Rust 核心团队(Core team)在执行社区行为准则和标准上...【详细内容】
2021-12-15  InfoQ    Tags:Rust   点击:(24)  评论:(0)  加入收藏
一个项目的大部分API,测试用例在参数和参数值等信息会有很多相似的地方。我们可以复制API,复制用例来快速生成,然后做细微调整既可以满足我们的测试需求1.复制API:在菜单发布单...【详细内容】
2021-12-14  AutoMeter    Tags:AutoMeter   点击:(20)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条