(P3)

面向对象的典型原则可以划分为两类 —— “面向类”的和“面向包”的;

“面向类”的,包括:
SRP —— 单一职责原则;
OCP —— 开放封闭原则;
LSP —— 里氏替换原则;
DIP —— 依赖倒置原则;
ISP —— 接口隔离原则;

“面向包”的,包括:
REP —— 重用发布等价原则;
CCP —— 共同封装原则;
CRP —— 共同重用原则;
ADP —— 无环依赖原则;
SDP —— 稳定依赖原则;
SAP —— 稳定抽象原则;

“面向包”的6个原则可以再划分为两类:REP、CCP、CRP 强调的是包的内聚性设计要求,而 ADP、SDP、SAP针对的是包间耦合性要求;

(P7)

里氏替换原则是站在模式对象这一方,依赖倒置原则是站在客户程序这一方。模式对象这一方将“相对多变的”子类视同它的接口(或父类),而客户程序依赖的内容不是“相对多变”的子类,而是“相对稳定”的接口;

(P10)

迪米特法则不希望与非“友”的类型建立直接联系,即便联系的都是“友”也要和“最近的密友”联系,并且联系的时候最好不要谈“隐私”(即专门类型),要用一些相对广为人知的知识进行交互;

迪米特法则在生活中最直观的表现就是“人脉”,不过不同点在于迪米特法则希望的是人脉窄,而现实中我们希望的是人脉宽、路子广;

(P15)

开发软件的主要目的是满足用户的需要,同时获得收益;

工程化软件的特点不仅仅是看上去很“面向对象”,关键是能够用简洁、必要的面向对象手段解决问题,少投入、多产出;

(P18)

好的命名空间规划是工程化代码与非工程化代码一个最直观的区别;

(P21)

在.Net中委托也是一个抽象手段,它是对方法的抽象;

(P22)

委托是对具体方法的抽象,它屏蔽了委托的调用者与实际执行方法间的关联关系;

(P25)

方法,就是一小段可以重用的处理过程;

事件是委托的特例,“特”表现在如下4个方面:
—— 返回值为 void;
—— 第一个参数 sender 是 System.Object;
—— 第二个参数继承自 EventArgs 或其子类;
—— 仅限两个参数;

(P29)

C# 为我们提供了5种抽象能力:
Class —— 对现实世界的抽象;
Interface —— 对 Class 行为的抽象;
Delegate —— 对方法的抽象;
Attribute —— 对类型元数据的抽象;
Generics —— 给上述因素进一步、进两步、直至进N步抽象的机会;

(P33)

接口和参数更明确,而且不仅仅停留在 UML 的图纸上,在编码和调用过程中都起到刚性的检查作用;

(P34)

如果代码将被反复重用,只要进度允许,尽量泛型;

(P49)

不建议在 .Net 2.0 版本以前的项目中采用接口注入的方式;

(P76)

工厂方法模式是 GOF 23个设计模式中最具启发效果的,它告诉我们可以通过增加新的对象专门管理“变化”;

(P78)

静态类不能被继承,所以看起来静态类更像以前的 API 集合,有点不那么“面向对象”的味道;

(P93)

单件模式要做的就是通过控制类型实例的创建过程,确保客户程序使用的都是创建好的同一个实例;

(P105)

Singleton 模式在 .Net 平台一个最简洁但又相对线程安全的实现方式:

sealed class Singleton
{
    Singleton() {}
    public static readonly Singleton Instance = new Singleton();
}

(P115)

使用时可以把工厂方法、静态工厂、简单工厂和抽象工厂混合起来:

静态工厂可以作为最底层的一个“泵”,它提供最原始但最粗颗粒度对象的创建,甚至仅仅返回弱类型的 object 也可以,后绑定调用(或被称为晚绑定)可以通过一个集中的静态工厂完成。之所以把它放在最下面,主要是因为它不能被继承和进一步扩展,所以让它做最基本但又最通用的工作。实际项目中可以用 Activator 类充当这个角色;

简单工厂的适用范围很广,根据应用的需要在某些需要隔绝抽象与具体的位置上使用;

工厂方法应用在具有一套较纵深层次的对象上,可以通过具体工厂类型选择继承层次上一个合适的具体产品来构造,而客户程序则把握住抽象的工厂类型和抽象的产品类型即可;

抽象工厂方法则用在某些特定领域上,面向某些应用子系统或专业领域的对象创建工作,相对而言,我们可以把它更多地用于项目的中、高层设计中;

(P142)

项目中,使用原型模式的关键不在于定义一个 IPrototype 接口,而在于如何又好又快地完成克隆过程;

(P148)

适配器主要有3个作用:
—— 完成旧接口到新接口的转换;
—— 将“既有系统”进行封装,逻辑上客户程序应该不知道“既有系统”的存在,将变化隔离在适配器部分;
—— 如果客户程序需要迁移,仅需要在适配器部分做修改;

适配器模式配合代理模式,它们能起到“稳定性边界”的作用,即当一个范围内的对象相对稳定,而与之交互范围内的对象相对不稳定(或不确定能否稳定)时,我们可以考虑在边界上增加适配器和代理;

(P166)

桥模式解决的是对抽象中正交变化因素的进一步分解及衔接;

(P206)

在实际项目中,装饰模式的应用比例不高,主要是因为追踪和调试相对困难,多数情况下项目中更愿意采用多接口组合的方式;

(P216)

值类型要么是堆栈分配的,要么是在结构中以内联方式分配的,值类型包括简单类型、枚举类型和结构类型;

引用类型是堆分配的,操作它们的时候我们是基于引用完成的,引用类型包括类类型、接口类型、委托类型和数组类型;

(P224)

外观模式是屏蔽复杂性的,很多时候代理模式的控制本身也就是对各种复杂性的屏蔽,只不过外观处理的是一个逻辑上的“子系统”,而且其封装后的结果并没有具体抽象接口的要求,但在代理模式中客户程序需要的接口事先是明确的。外观模式往往会生成一个更易于使用的新接口,而代理模式保持接口一致;

(P226)

代理模式既以设计模式出现,用时也是很重要的架构模式;

(P237)

CoR 模式广泛应用于架构模式、大型项目的基础平台及 SOA 环境下的企业服务总线(Enterprise Service Bus, ESB),其交互过程中往往涉及分布式事务性链式操作,消息队列、数据库、外部服务及云计算环境都可以针对一个 Request 内容用“链式”方法连接;

(P242)

模板方法模式的概念虽然简单,但它却充斥在软件架构的方方面面;

(P245)

模板方法模式主要采用继承(或接口实现)完成,而策略模式更多通过委托解决;

模板方法模式关注点在于算法中的每个步骤的差异及可替换性,而策略模式则是对整个算法进行替换;

(P273)

从工程角度看,命令模式最大的优势在于它为应用的扩展性、高可用性提供了基础;

(P284)

“依赖于抽象” —— 如果客户程序使用一个继承体系上的某个具体类型的时候,就从这个体系上抽象出一个接口,然后通过创建型模式让客户程序按照接口要求向客户程序提供实例;

(P295)

备忘录模式是为了给应用一个 Undo() 的机会;

(P317)

ABC (Address、Binding、Contract) 组合常被称为 (ServiceEndpoint);

(P333)

命令模式解决的是“做什么”,它把到底需要做什么的问题延迟到子类中定义;

策略模式关注于“怎么做”,也就是为了完成一个既定的处理,算法上怎么实现的问题;

(P351)

如果对象的不确定性来自于构造过程,那么借助“创建型模式”,控制目标对象的数量或者把创建工作交给一个独立的对象完成。这样,业务对象自身不会为了构造其他对象产生直接依赖。当然,实现该目标有一个前提,那就是待构造的对象先被抽象;

如果对象的不确定性来自结构,则可以考虑“结构型模式”,用一个相对抽象的对象协调结构上的依赖关系;

如果不确定性来自执行过程,则可以考虑“行为型模式”,行为型模式多数时候是对执行逻辑复杂性的进一步分解,比如某些操作、交互过程过于复杂,这时就需要对它们分解。行为型的思维方法就是把这些复杂而且易变操作和交互对象化,同时抽象它们的行为,确保这些对象后续可以被替换;

(P381)

视野决定高度;

《模式 工程化实现及扩展 (设计模式 C#版)》 - 书摘精要的更多相关文章

  1. 【EatBook】-NO.2.EatBook.2.JavaArchitecture.1.001-《修炼Java开发技术在架构中体验设计模式和算法之美》-

    1.0.0 Summary Tittle:[EatBook]-NO.2.EatBook.2.JavaArchitecture.1.001-<修炼Java开发技术在架构中体验设计模式和算法之美&g ...

  2. 《修炼Java开发技术 在架构中体验设计模式和算法之美》 - 书摘精要

    (P7) 建议直接加入到软件公司中去,这样会学到很多实际的东西: 程序员最主要的发展方向是资深技术专家,无论是 Java..Net 还是数据库领域,都要首先成为专家,然后才可能继续发展为架构师: 增强 ...

  3. 测试开发技术:DOM中 innerHTML、innerText、outerHTML、outerText的区别

    测试开发技术:DOM中 innerHTML.innerText.outerHTML.outerText的区别   我们在做web自动化的过程中通过dom处理web页面元素,那么你就要了解innerHT ...

  4. Java基础语法(8)-数组中的常见排序算法

    title: Java基础语法(8)-数组中的常见排序算法 blog: CSDN data: Java学习路线及视频 1.基本概念 排序: 是计算机程序设计中的一项重要操作,其功能是指一个数据元素集合 ...

  5. Java开发技术大揭底——让你认知自己技术上的缺陷,成为架构师

    一.分布式架构体系 分布式怎么来的.传统的电信.银行业,当业务量大了之后,普通服务器CPU/IO/网络到了100%,请求太慢怎么办?最直接的做法,升级硬件,反正也不缺钱,IBM小型机,大型机,采购了堆 ...

  6. 2020 年最流行的 Java 开发技术

    不知不觉间,2020 年即将于十几天之后到来,作为技术圈中你,准备好迎接最新的变化了吗?在本文中,我们将以编程界最常用的编程语言 Java 为例,分享最为主流的技术与工具. 作者 | divyesh. ...

  7. 手机端UC浏览器,在java开发的下载功能中存在的问题?

    在java web开发中,不同浏览器对下载文件的格式有不同的要求,有时会出现视频,音频等文件无法下载的问题.我在开发中,也遇到类似的问题,觉得很苦恼. 经过百度和请教学习,得到2个解决方案. 首先得到 ...

  8. 个人总结的一个中高级Java开发工程师或架构师需要掌握哪几点!

    今天,我来唠叨几句~~ 知识改变命运,对于Java程序员来说,技术不断更新,只有及时充电,才能不被市场淘汰.今天为大家分享Java程序员学习的6个小技巧. 1.一定要看书 现在学习Java变得比以前容 ...

  9. Java开发技术

    1.基础技术 数据结构与算法   逻辑结构:数据对象中的数据元素之间的逻辑关系 1.集合结构:集合结构中的数据元素除了同属一个集合外,没有其他关系. 2.线性结构:线性结构中的数据元素之间是一对一的关 ...

  10. 【饿了么】招聘Java开发工程师、架构师

    3年以上实际工作经验,本科及以上学历. 具有良好的编程基础( 比如熟悉HTTP.多线程.Socket.JVM.基本的数据结构和算法等). 熟悉Java语言以及相关的服务器(比如Tomcat).工具(M ...

随机推荐

  1. boost atomic

    文档: http://www.boost.org/doc/libs/1_53_0/doc/html/atomic.html Presenting Boost.Atomic Boost.Atomic i ...

  2. c++ ScopeExitGuard

    说到Native Languages就不得不说资源管理,因为资源管理向来都是Native Languages的一个大问题,其中内存管理又是资源当中的一个大问题,由于堆内存需要手动分配和释放,所以必须确 ...

  3. Java集合(1):ArrayList

    Java容器类的用途是“保存对象”,分为两类:Map——存储“键值对”组成的对象:Collection——存储独立元素.Collection又可以分为List和Set两大块.List保持元素的顺序(有 ...

  4. WIN7下PHP无法开启CURL,终极解决方案

    常规做法: 1)extension=php_curl.dll之外 2)把libeay32.dll.ssleay32.dll.php_curl.dll复制到C:\Windows\SysWOW64目录下 ...

  5. Oracle中对现有表增加列

    altertable Tablename add(column1 varchar2(20),column2 number(7,2)...) --Oracle中修改列名不可以,但是可以删除列,增加列 a ...

  6. 配置nginx,Tomcat日志记录请求耗时

    由于公司的业务比较特殊,对速度比较在意,客户最近反应我们的平台时间比较久,处理一个请求十秒左右才返回,领导要求找出原因,我想让nginx日志记录请求处理用了多长时间,后端处理用了多长时间,总共用了多长 ...

  7. COS-8文件系统

    操作系统(Operating System,简称OS)是管理和控制计算机硬件与软件资源的计算机程序,是直接运行在“裸机”上的最基本的系统软件,任何其他软件都必须在操作系统的支持下才能运行.   操作系 ...

  8. 【转载】在block中使用weakSelf/strongSelf

    http://blog.lessfun.com/blog/2014/11/22/when-should-use-weakself-and-strongself-in-objc-block/

  9. iOS开发小结 - 关于swift中#if DEBUG判断不执行的解决方案

    在以前的OC项目中我们经常用#if DEBUG来判断是否是在DEBUG模式下调试代码,然后最近我用swift写的项目中发现#if DEBUG判断居然不管用了,多方查证为果的情况下终于找到了解决方案,希 ...

  10. iOS开发进阶 - 日志输出框架CocoaLumberjack与XcodeColors插件的简单使用(swift版)

    CocoaLumberjack是Mac和iOS上一个集快捷.简单.强大和灵活于一身的日志框架.XcodeColors是用于控制台着色的工具,配合着CocoaLumberjack用有更好的效果,不废话, ...