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.面向对象设计原则的更多相关文章

  1. 学习记录:《C++设计模式——李建忠主讲》1.设计模式

    1.学习目标 1)理解松耦合设计思想: 2)掌握面向对象设计原则: 3)掌握重构技法改善设计: 4)掌握GOF核心设计模式: 2.定义 每个设计模式描述了一个在我们周围不断重复发生的问题,以及该问题解 ...

  2. 学习记录:《C++设计模式——李建忠主讲》3.“组件协作”模式

    “组件协作”模式:现代软件专业分工之后的第一个结果是“框架与应用程序的划分”,“组件协作”模式通过晚期绑定,来实现框架与应用程序之间的松耦合,是二者之间协作时常用的模式.典型模式:Template M ...

  3. 学习记录:《C++设计模式——李建忠主讲》6.“状态变化”模式

    状态变化模式:在组件构建过程中,某些对象的状态经常面临变化,如何对这些变化进行有效的管理?同时又维持高层模块的稳定.状态变化模式为这一问题提供了一种解决方案. 典型模式:状态模式(State).备忘录 ...

  4. 学习记录:《C++设计模式——李建忠主讲》5.“对象性能”模式

    对象性能模式:面向对象很好地解决了抽象地问题,但是必不可免地要付出一定地代价.对于通常情况来讲,面向对象地成本大都可以忽略不计,但某些情况,面向对象所带来地成本必须谨慎处理. 典型模式:单件模式(Si ...

  5. 学习记录:《C++设计模式——李建忠主讲》4.“单一职责”模式

    单一职责模式:在软件组件的设计中,如果责任划分的不清晰,使用继承得到的结果往往是随着需求的变化,子类急剧膨胀,同时充斥着重复代码,这时候的关键是划清责任. 典型模式:装饰模式(Decorator).桥 ...

  6. 学习记录:《C++设计模式——李建忠主讲》7.“领域规则”模式

    领域规则模式:在特定领域中,某些变化虽然频繁,但可以抽象为某种规则.这时候,结合特定的领域,将问题抽象为语法规则,从而给出该领域下的一般性解决方案. 典型模式:解释器模式(Interpreter). ...

  7. 工厂模式(整理自李建忠<C++设计模式>视频)

    整理自李建忠<C++设计模式>视频 一.导入:"对象创建"模式和工厂模式 工厂模式只是该模式下的一种. 二.举例说明 有这样一个场景:需要在MainForm中设计一个按 ...

  8. Java设计模式学习记录-GoF设计模式概述

    前言 最近要开始学习设计模式了,以前是偶尔会看看设计模式的书或是在网上翻到了某种设计模式,就顺便看看,也没有仔细的学习过.前段时间看完了JVM的知识,然后就想着JVM那么费劲的东西都看完了,说明自己学 ...

  9. Lua和C++交互 学习记录之九:在Lua中以面向对象的方式使用C++注册的类

    主要内容转载自:子龙山人博客(强烈建议去子龙山人博客完全学习一遍) 部分内容查阅自:<Lua 5.3  参考手册>中文版 译者 云风 制作 Kavcc vs2013+lua-5.3.3 在 ...

随机推荐

  1. 1.在ubuntu中软件安装在哪里?

    ubuntu下安装软件有四种方式: 1.通过deb格式的离线软件包安装 sudo dpkg -i xxx.deb # 安装包,安装程序   -i: install sudo dpkg -r packa ...

  2. SpringMvc启动源码解析

    1. 前言 上篇文章介绍了Spring容器的初始化https://www.cnblogs.com/xiaobingblog/p/11738747.html,接下来介绍SpringMvc容器的初始化 2 ...

  3. 说说hashCode() 和 equals() 之间的关系?

    上一篇关于介绍Object类下的几种方法时面试题时,提到equals()和hashCode()方法可能引出关于“hashCode() 和 equals() 之间的关系?”的面试题,本篇来解析一下这道基 ...

  4. java中JVM内存管理(1)

    Java岗位面试,JVM是对程序员基本功考察,通常会问你对JVM了解吗?  可以分几部分回答这个问题,首先JVM内存划分 | JVM垃圾回收的含义  |  有哪些GC算法  以及年轻代和老年代各自特点 ...

  5. Redis备忘(一)

    hash: 渐进式rehash:同时查询新旧两个hash,然后在后续定时任务以及hash的子指令中,循序渐进将旧的迁移到新的hash表 Redis应用: 1.分布式锁: 实现1:setnx+expir ...

  6. Java日志Log4j或者Logback的NDC和MDC功能

    NDC和MDC的区别 Java中使用的日志的实现框架有很多种,常用的log4j和logback以及java.util.logging,而log4j是apache实现的一个开源日志组件(Wrapped ...

  7. 利用span设置文字固定宽度

    <input type="radio" name="dispMode" id="rdoManul" value="manul ...

  8. [考试反思]0908NOIP模拟测试40:颠簸

    怎么说呢?好像也没什么可说的. 把我的优缺点都表现出来了的一场考试. T3是个小的dp想出来就能打,打出来就能A.我上来过了一遍题目觉得T3最简单(然而也并不是很简单) 然后就开始打,交,其实已经A了 ...

  9. NOIP模拟34

    考试的时候被T2卡了一年....考虑了一下正解的式子,然后没去给左边分解因数,去给后面乘倍数...理论复杂度O(n^2),实际好像卡不掉的样子.但是由于我智障的打了一棵主席树,他M了.... 预计得分 ...

  10. JDK下载安装配置教程(详细)

    JDK下载安装配置教程(详细) 版权声明:本文为原创文章,转载请附上原文出处链接和本声明.https://www.cnblogs.com/mxxbc/p/11844885.html 因为最近需要在Wi ...