《模式 工程化实现及扩展 (设计模式 C#版)》 - 书摘精要
(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#版)》 - 书摘精要的更多相关文章
- 【EatBook】-NO.2.EatBook.2.JavaArchitecture.1.001-《修炼Java开发技术在架构中体验设计模式和算法之美》-
1.0.0 Summary Tittle:[EatBook]-NO.2.EatBook.2.JavaArchitecture.1.001-<修炼Java开发技术在架构中体验设计模式和算法之美&g ...
- 《修炼Java开发技术 在架构中体验设计模式和算法之美》 - 书摘精要
(P7) 建议直接加入到软件公司中去,这样会学到很多实际的东西: 程序员最主要的发展方向是资深技术专家,无论是 Java..Net 还是数据库领域,都要首先成为专家,然后才可能继续发展为架构师: 增强 ...
- 测试开发技术:DOM中 innerHTML、innerText、outerHTML、outerText的区别
测试开发技术:DOM中 innerHTML.innerText.outerHTML.outerText的区别 我们在做web自动化的过程中通过dom处理web页面元素,那么你就要了解innerHT ...
- Java基础语法(8)-数组中的常见排序算法
title: Java基础语法(8)-数组中的常见排序算法 blog: CSDN data: Java学习路线及视频 1.基本概念 排序: 是计算机程序设计中的一项重要操作,其功能是指一个数据元素集合 ...
- Java开发技术大揭底——让你认知自己技术上的缺陷,成为架构师
一.分布式架构体系 分布式怎么来的.传统的电信.银行业,当业务量大了之后,普通服务器CPU/IO/网络到了100%,请求太慢怎么办?最直接的做法,升级硬件,反正也不缺钱,IBM小型机,大型机,采购了堆 ...
- 2020 年最流行的 Java 开发技术
不知不觉间,2020 年即将于十几天之后到来,作为技术圈中你,准备好迎接最新的变化了吗?在本文中,我们将以编程界最常用的编程语言 Java 为例,分享最为主流的技术与工具. 作者 | divyesh. ...
- 手机端UC浏览器,在java开发的下载功能中存在的问题?
在java web开发中,不同浏览器对下载文件的格式有不同的要求,有时会出现视频,音频等文件无法下载的问题.我在开发中,也遇到类似的问题,觉得很苦恼. 经过百度和请教学习,得到2个解决方案. 首先得到 ...
- 个人总结的一个中高级Java开发工程师或架构师需要掌握哪几点!
今天,我来唠叨几句~~ 知识改变命运,对于Java程序员来说,技术不断更新,只有及时充电,才能不被市场淘汰.今天为大家分享Java程序员学习的6个小技巧. 1.一定要看书 现在学习Java变得比以前容 ...
- Java开发技术
1.基础技术 数据结构与算法 逻辑结构:数据对象中的数据元素之间的逻辑关系 1.集合结构:集合结构中的数据元素除了同属一个集合外,没有其他关系. 2.线性结构:线性结构中的数据元素之间是一对一的关 ...
- 【饿了么】招聘Java开发工程师、架构师
3年以上实际工作经验,本科及以上学历. 具有良好的编程基础( 比如熟悉HTTP.多线程.Socket.JVM.基本的数据结构和算法等). 熟悉Java语言以及相关的服务器(比如Tomcat).工具(M ...
随机推荐
- boost atomic
文档: http://www.boost.org/doc/libs/1_53_0/doc/html/atomic.html Presenting Boost.Atomic Boost.Atomic i ...
- c++ ScopeExitGuard
说到Native Languages就不得不说资源管理,因为资源管理向来都是Native Languages的一个大问题,其中内存管理又是资源当中的一个大问题,由于堆内存需要手动分配和释放,所以必须确 ...
- Java集合(1):ArrayList
Java容器类的用途是“保存对象”,分为两类:Map——存储“键值对”组成的对象:Collection——存储独立元素.Collection又可以分为List和Set两大块.List保持元素的顺序(有 ...
- WIN7下PHP无法开启CURL,终极解决方案
常规做法: 1)extension=php_curl.dll之外 2)把libeay32.dll.ssleay32.dll.php_curl.dll复制到C:\Windows\SysWOW64目录下 ...
- Oracle中对现有表增加列
altertable Tablename add(column1 varchar2(20),column2 number(7,2)...) --Oracle中修改列名不可以,但是可以删除列,增加列 a ...
- 配置nginx,Tomcat日志记录请求耗时
由于公司的业务比较特殊,对速度比较在意,客户最近反应我们的平台时间比较久,处理一个请求十秒左右才返回,领导要求找出原因,我想让nginx日志记录请求处理用了多长时间,后端处理用了多长时间,总共用了多长 ...
- COS-8文件系统
操作系统(Operating System,简称OS)是管理和控制计算机硬件与软件资源的计算机程序,是直接运行在“裸机”上的最基本的系统软件,任何其他软件都必须在操作系统的支持下才能运行. 操作系 ...
- 【转载】在block中使用weakSelf/strongSelf
http://blog.lessfun.com/blog/2014/11/22/when-should-use-weakself-and-strongself-in-objc-block/
- iOS开发小结 - 关于swift中#if DEBUG判断不执行的解决方案
在以前的OC项目中我们经常用#if DEBUG来判断是否是在DEBUG模式下调试代码,然后最近我用swift写的项目中发现#if DEBUG判断居然不管用了,多方查证为果的情况下终于找到了解决方案,希 ...
- iOS开发进阶 - 日志输出框架CocoaLumberjack与XcodeColors插件的简单使用(swift版)
CocoaLumberjack是Mac和iOS上一个集快捷.简单.强大和灵活于一身的日志框架.XcodeColors是用于控制台着色的工具,配合着CocoaLumberjack用有更好的效果,不废话, ...