学习记录:《C++设计模式——李建忠主讲》2.面向对象设计原则
1.课程内容:
重新认识面向对象;面向对象设计原则;
2.重新认识面向对象
1)理解隔离变化:从宏观层面来看,面向对象的构建方式更能适应软件的变化,将变化所带来的影响减为最小;
2)各司其职:从微观层面来看,面向对象更强调各个类的责任;由于需求变化导致的新增类型不应该影响原来类型的实现;
3)对象是什么:从语言实现层面来看,对象封装了代码和数据;从规格层面讲,对象是一系列可被使用的公共接口;从概念层面讲,对象是某种拥有责任的抽象。
3.面向对象设计原则
3.1 依赖倒置原则(DIP:Dependence Inversion Principle)
1)高层模块(稳定)不应该依赖低层模块(变化),二者都应该依赖于抽象(稳定);
2)抽象(稳定)不应该依赖于实现细节(变化),实现细节应该依赖于抽象。
理解:一般情况下抽象的变化概率很小,让用户程序依赖于抽象,实现的细节也依赖于抽象。即使实现细节不断变动,只要抽象不变,客户程序就不需要变化。这大大降低了客户程序与实现细节的耦合度。
例子:在上篇随笔中,关于Line和Rect的绘制实现上,分解方案MainForm依赖于Line和Rect,这是不符合DIP原则的,其中MainForm是高层模块,Line和Rect是低层模块;而在抽象方案中MainForm依赖于抽象类Shape,不依赖于Line和Rect,Shape比较稳定,Line和Rect也依赖于较稳定的Shape。
3.2 开放封闭原则(OCP:Open Closed Principle)
1)一个类应该仅有一个能引起它变化的原因;
2)变化的方向隐含着类的责任
理解:一个类,只有一个引起它变化的原因,应该只有一个职责。每一个职责都是变化的一个轴线,如果一个类有一个以上的职责,这些职责就耦合在了一起,这会导致脆弱的设计。
例子:在上篇随笔中,关于Line和Rect的绘制实现上,当增加圆的绘制时,分解方案要修改MainForm的代码,并且增加Circle类,没有遵循OCP原则;而在抽象方案中只增加了Circle类(扩展),没有修改,遵循了OCP原则。
3.4 Liskov替换原则(LSP:Liskov Substitution Principle)
1)子类必须能够替换它们的基类(IS-A);
2)继承表达类型抽象;
理解:任何基类可以出现的地方,子类一定可以出现;只有当衍生类可以替换掉基类,软件单位的功能不受到影响时,基类才能真正被复用;
3.5 接口隔离原则(ISP:Interface Segregation Principle)
1)不应该强迫客户程序依赖它们不用的方法;
2)接口应该小而完备;
理解:客户端不应该依赖它不需要的接口;一个类对另一个类的依赖应建立在最小的接口上。
3.6 优先使用对象组合,而不是类继承
1)类继承通常为“白箱复用”,对象组合通常为“黑箱复用”;
2)继承某种程度上破环了封装性,子类基类耦合度高;
3)对象组合只要求被组合的对象居于良好定义的接口,耦合度低;
理解:继承和组合都能达到一个代码复用的效果,我们在使用继承的时候同时也就拥有了基类中的保护成员,增加了耦合度。而对象组合就只需要在使用的时候接口稳定,耦合度低。
3.7 封装变化点
1)使用封装来创建对象之间的分解层,让设计者可以在分解层的一侧进行修改,而不会对另一侧产生不良的影响,从而实现层次间的松耦合;
理解:
3.8 针对接口编程,而不是针对实现编程
1)不将变量类型声明为某个特定的具体类,而是声明为某个接口。
2)客户程序无需获知对象的具体类型,只需要知道对象所具有的接口。
3)减少系统中各部分的依赖关系,从而实现“高内聚、松耦合”的类型设计方案。
理解:和依赖倒置原则是相辅相成的。接口标准化是产业强盛的标志。
参考:《李建忠C++设计模式》视频
https://www.bilibili.com/video/av64805906/?p=2
学习记录:《C++设计模式——李建忠主讲》2.面向对象设计原则的更多相关文章
- 学习记录:《C++设计模式——李建忠主讲》1.设计模式
1.学习目标 1)理解松耦合设计思想: 2)掌握面向对象设计原则: 3)掌握重构技法改善设计: 4)掌握GOF核心设计模式: 2.定义 每个设计模式描述了一个在我们周围不断重复发生的问题,以及该问题解 ...
- 学习记录:《C++设计模式——李建忠主讲》3.“组件协作”模式
“组件协作”模式:现代软件专业分工之后的第一个结果是“框架与应用程序的划分”,“组件协作”模式通过晚期绑定,来实现框架与应用程序之间的松耦合,是二者之间协作时常用的模式.典型模式:Template M ...
- 学习记录:《C++设计模式——李建忠主讲》6.“状态变化”模式
状态变化模式:在组件构建过程中,某些对象的状态经常面临变化,如何对这些变化进行有效的管理?同时又维持高层模块的稳定.状态变化模式为这一问题提供了一种解决方案. 典型模式:状态模式(State).备忘录 ...
- 学习记录:《C++设计模式——李建忠主讲》5.“对象性能”模式
对象性能模式:面向对象很好地解决了抽象地问题,但是必不可免地要付出一定地代价.对于通常情况来讲,面向对象地成本大都可以忽略不计,但某些情况,面向对象所带来地成本必须谨慎处理. 典型模式:单件模式(Si ...
- 学习记录:《C++设计模式——李建忠主讲》4.“单一职责”模式
单一职责模式:在软件组件的设计中,如果责任划分的不清晰,使用继承得到的结果往往是随着需求的变化,子类急剧膨胀,同时充斥着重复代码,这时候的关键是划清责任. 典型模式:装饰模式(Decorator).桥 ...
- 学习记录:《C++设计模式——李建忠主讲》7.“领域规则”模式
领域规则模式:在特定领域中,某些变化虽然频繁,但可以抽象为某种规则.这时候,结合特定的领域,将问题抽象为语法规则,从而给出该领域下的一般性解决方案. 典型模式:解释器模式(Interpreter). ...
- 工厂模式(整理自李建忠<C++设计模式>视频)
整理自李建忠<C++设计模式>视频 一.导入:"对象创建"模式和工厂模式 工厂模式只是该模式下的一种. 二.举例说明 有这样一个场景:需要在MainForm中设计一个按 ...
- Java设计模式学习记录-GoF设计模式概述
前言 最近要开始学习设计模式了,以前是偶尔会看看设计模式的书或是在网上翻到了某种设计模式,就顺便看看,也没有仔细的学习过.前段时间看完了JVM的知识,然后就想着JVM那么费劲的东西都看完了,说明自己学 ...
- Lua和C++交互 学习记录之九:在Lua中以面向对象的方式使用C++注册的类
主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3 参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 在 ...
随机推荐
- webpack 打包 todolist 应用
写在前面的话: 一直想着手动配置webpack实现应用,正好最近这段时间比较空闲,就写了一个通过webpack打包实现todolist的简单应用.本文内容包括:通过webpack打包css,html ...
- Vuex的简单应用
### 源码地址 https://github.com/moor-mupan/mine-summary/tree/master/前端知识库/Vuex_demo/demo 1. 什么是Vuex? Vue ...
- Class constructor FileManager cannot be invoked without 'new'
bug:今天项目重新安装依赖打包的时候出现错误:Class constructor FileManager cannot be invoked without 'new' 解决:尝试了很多种解决方案, ...
- printf 格式输出代码大全
d,lx,ld,,lu,这几个都是输出32位的hd,hx,hu,这几个都是输出16位数据的,hhd,hhx,hhu,这几个都是输出8位的,lld,ll,llu,llx,这几个都是输出64位的, pri ...
- Java多线程编程(四)Lock的使用
一.使用ReentrantLock类 在Java多线程中,可以使用synchronized关键字来实现线程之间的同步互斥,但ReentrantLock类也能达到同样的效果,并且在扩展功能上也更加强大, ...
- 爬虫链接mongodb 以及多线程多进程的操作
一.连接mongodb 1. 设置数据库 client=pymongo.MongoClient(‘localhost’) 2. db=client[‘lag ...
- 务必收藏备用:.net core中通过Json或直接获取图形验证码(数字验证码、字母验证码、混合验证码),有源代码全实战demo(开源代码.net core3.0)
很多人写的博客大家看了会一知半解,不知道怎么用,应该引用什么类库或者代码不全,这样很多小白很是头疼,尤其是尝新技术更是如此.我们这边不止告诉你步骤,而且还提供开源demo.随着时间的推移,我们的dem ...
- VSCode实现文献管理
1 常用文献管理软件 常用的文献管理软件有mendely,zotero,endnote和Papers(需要付费),具体对比参考链接1.1.1.2 笔者只用过Mendely,当时综合考虑挑了Endnot ...
- 基于SkyWalking的分布式跟踪系统 - 微服务监控
上一篇文章我们搭建了基于SkyWalking分布式跟踪环境,今天聊聊使用SkyWalking监控我们的微服务(DUBBO) 服务案例 假设你有个订单微服务,包含以下组件 MySQL数据库分表分库(2台 ...
- C语言作业007
问题 答案 这个作业属于那个课程 C语言程序设计1 这个作业要求在哪里 我在这个课程的目的是 学习并掌握C语言 这个作业在那个具体方面帮助我实现目标 参考文献 四 作业格式 1PTA作业贴图 1.1题 ...