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. office visio 2019 下载激活

    安装 下载 office ed2k://|file|cn_office_professional_plus_2019_x86_x64_dvd_5e5be643.iso|3775004672|1E4FF ...

  2. 搭建ASP.NET Core WebApi项目

    步骤 从“文件”菜单中选择“新建”>“项目” . 选择“ASP.NET Core Web 应用程序”模板,再单击“下一步” . 将项目命名为 NetCoreWebApi,然后单击“创建” . 选 ...

  3. 继承+派生+分类+钻石继承(day20)

    目录 昨日内容 面对对象编程 类 定义类时发生的事情 调用类时发生的事情 init 对象 对象查找类的属性的顺序 对象的绑定方法 python中万物皆对象 今日内容 继承 什么是继承 为什么要继承 如 ...

  4. OptimalSolution(4)--字符串问题(1)简单

    一.判断两个字符串是否互为变形词 问题:给定两个字符串str1和str2,如果str1和str2中出现的字符种类一样且每种字符出现的次数也一样,那么str1与str2互为变形词. 举例:str1=“1 ...

  5. Java基础(三)对象与类

    1.类的概念:类是构造对象的模板或蓝图.由类构造对象的过程称为创建类的实例. 2.封装的概念:封装(有时称为数据隐藏)是与对象有关的一个重要概念.对象中的数据称为实例域,操纵数据的过程称为方法.对于每 ...

  6. 我发现了Unity3D的2D Light Renderer, 随后就把它抄了过来

    . 前几个月,偶然在群里看到有人讨论Unity3D光照,于是我又萌生了一个新的目标----把它抄过来! . 众所周知,3D渲染的整个流水线都跟光照密不可分,相关的技术更是数不甚数,而2D游戏的光照通常 ...

  7. Ios 开发 mac cocoaPods的环境搭建

    CocoaPods不多介绍,一个大家几乎都会使用的第三方库的管理框架! 本文主要介绍如何安装和使用CocoaPods,本人亲测可行. 1.Ruby环境搭建 查看下当前ruby版本: ruby -v 更 ...

  8. java和Jvm目录

    回到占占推荐博客索引 主要介绍java基础知识,非框架类及JVM相关的内容文章 java和Jvm目录 Java~关于开发工具和包包 Java~类,抽象类和接口 Java~时间戳小知识 Java~命名规 ...

  9. 身份证号码验证算法(php和js实现)

    原文:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=21126994&id=3938244 http://www.jb ...

  10. C语言I—2019秋作业01

    1您对软件工程专业或计算机科学与技术专业了解是什么? 工程专业将成为一个新的热门专业.软件工程专业以计算机科学与技术学科为基础,突出软件开发的工程性,使学生在掌握计算机科学与技术方面知识和技能的基础上 ...