《大话设计模式》读书笔记1

通过阅读《大话设计模式》这本书,初步了解了设计模式,以及我以前对设计模式的一些误解。

几条心得如下:

1.设计模式并不只是一种方法,更是一种思想。

2.设计模式和具体的语言没有关系,学习设计模式最重要的目的就是要建立面向对象的思想,尽可能地面向接口编程,高内聚,低耦合,使设计的程序可复用。

3.在进行程序设计时,不要总想着往某个设计模式上套,这是没有真正掌握设计模式思想的表现。

4.学习设计模式,一定要勤学多练。

创建型模式

1.工厂方法模式

使用时机:当在代码中使用new来创建比较复杂的对象时,可以考虑使用工厂方法模式,

优点:具体的工厂类负责对象的创建,客户端负责对象的调用。

如果有新的产品加进来,只需新增一个具体的创建产品工厂类和具体的产品类即可,不会影响原来的代码,后期维护更容易,增强了系统的可扩展性。

缺点:需要额外编写代码,增加工作量。

2.抽象工厂模式

使用时机:当系统需要创建一系列相互关联的对象时,需要使用抽象工厂模式。

优点:具体的工厂类负责对象的创建,客户端负责对象的调用,从而明确各个类的职责。

当一系列相互关联的产品被设计到一个工厂类里后,客户端的调用将会变得非常简单,而且,如果要更换这一系列的产品,只需要更换一个工厂类即可。

缺点:如果有新的产品加进来,则需要修改抽象工厂类的设计,并同时修改实现这个抽象工厂类的具体工厂类,需要额外编写代码,增加了工作量。

3.创建者模式

使用时机:当系统需要创建一个复杂的对象,而且这个复杂的对象组装起来比较麻烦时,就可以使用创建者模式。

优点:在创建者模式中,客户端不再负责对象的创建组装,而是把这个常见的责任交给具体的创建者类,吧组装的负责责任交给组装类,客户端只负责对象的调用,从而明确了各个类的职责。

缺点:虽然利用创建者模式可以创建出不同的类型的产品,但是如果产品之间的差异巨大,则需要编写多个创建者类才能实现,这时如果给结合工厂模式就更好了。

4.原型模式

使用时机:当系统需要创建的对象是动态加载的,而且产品具有一定层次时,需要使用原型模式。

优点:在此模型中,可以动态地添加产品类,而且对整体结构没有影响。

缺点:由于对原型类中的每个类配备一个克隆的方法,这就需要在设计类时通盘考虑,因为在已有类的基础上来添加clone操作是比较困难的,而且原型模式在实现深层次的复制时,需要编写一定量的代码。

5.单例模式

使用时机:当系统需要一个类只有一个实例时,就需要使用单例模式。

优点:在单例模式中,客户调用类的实例时。只能调用一个公共的接口,这就为整个开发团队提供了一个共享的概念。

缺点:实现单例模式的类在实例化后,不能被别的类继承,在分布式系统中,当系统中的单例类被复制运行在多个虚拟机下是,在每一个虚拟机下都会创建一个实例对象,此时如果想知道具体哪个虚拟机下运行着多少个单例对象是很困难的,而且单例类很难实现序列化。

时间: 2024-10-27 11:51:20

《大话设计模式》读书笔记1的相关文章

《android开发艺术探索》读书笔记(五)--动画

接上篇<android开发艺术探索>读书笔记(五)--Drawable No1: 自定义动画:派生一种新动画只需要继承Animation这个抽象类,然后重写它的initialize和applyTransformation方法,在initialize方法中做一些初始化工作,在applyTransformation中进行相应的矩阵变换即可,很多时候需要采用Camera来简化矩阵变换的过程. No2: 属性动画PropertyAnimation 补间动画TweenAnimation 帧动画Frame

《android开发艺术探索》读书笔记(十三)--综合技术

接上篇<android开发艺术探索>读书笔记(十二)--Bitmap的加载和Cache No1: 使用CrashHandler来获取应用的crash信息 No2: 在Android中单个dex文件所能够包含的最大方法数为65536,这包含Android FrameWork.依赖的jar包以及应用本身的代码中的所有方法. No3: 使用multidex来解决方法数越界 apply plugin: 'com.android.application' android { compileSdkVers

《android开发艺术探索》读书笔记(十五)--Android性能优化

接上篇<android开发艺术探索>读书笔记(十四)--JNI和NDK编程 No1: 如果<include>制定了这个id属性,同时被包含的布局文件的根元素也制定了id属性,那么以<include>指定的id属性为准 No2: 绘制优化 1)onDraw中不要创建新的局部对象 2)onDraw方法中不要做耗时的任务 No3: 内存泄露优化 场景一:静态变量导致的内存泄露: 如果静态变量持有了一个Activity,会导致Activity无法及时释放. 解决办法:1使用Ap

&lt;王二的经济学故事&gt;读书笔记

不是简单地用价格把供需弄平衡就完事了,座位分配给谁同样重要 一个成功的社会必须要有成功的人,必须要给成功的人应得的回报 需求曲线向下倾斜,价格越高需求越少 先来的都是那些时间最不值钱的 无论收入分配差距的根源是什么,收入分配差距的拉大,在一个市场经济的环境下,必然会造成富人对穷人的挤出效应,特别是在那些供给相对有限而需求相对刚性的瓶颈部门. 一个国家只能由一个公共财政体系,而需要服务的却是10多亿状况非常不同的老百姓 没有工资自然不用缴收入所得税,而且,自己一家的开销可以做成公司成本,从而降低公

《Android开发艺术探索》读书笔记之Activity的生命周期

两种不同情况下的Activity生命周期 (1)典型情况下的生命周期 指在有用户参与的情况下,Activity所经过的生命周期的改变. (2)异常情况下的生命周期 指Activity被系统回收或者由于当前设备的Configuration发生改变重而导致Activity被销毁传重建. 看看官方文档的Activity生命周期图 注意以下几点: (1)onstart()和onResume()从实际使用过程来说差不多,但是onstart()的时候Activity虽然可见啦但是还在后台,onResume(

《android开发艺术探索》读书笔记(八)--WindowManager

No1: Window是一个抽象类,它的具体实现是PhoneWindow.创建一个Window是很简单的事,只需要通过WindowManager即可完成. WindowManager是外界访问Window的入口,Window的具体实现位于WindowManagerService中,WindwoManager和WindowManagerService的交互时一个IPC过程. Android中所有的视图都是通过Window来呈现的,因此Window实际是View的直接管理者. 单机事件由Window

《艺术的故事》-读书笔记1

1.关于艺术家们画的不够逼真的作品 毫无疑问,现代艺术家们有足够的知识作出更逼真的作品,因此,当我们看到一副画画的不够正确时,首先应该考虑两件事,一件事是艺术家是否无端地更改了他所见的事物 的外形,另一件事是除非已经证明我们的看法正确而画家是错的,否则就不能指责一幅画画的不正确.一幅作品不够正确的地方也许正是了解它的钥匙. 2.关于什么是美?为何美?如何创造美?也许很难回答,但是美学感受却是可以通过对美好事物的不断观赏,分析来提高的. 3.知之为知之,不知为不知,是知也. 注:本文观点为<艺术的

Unix编程艺术读书笔记(一)

 Unix编程艺术读书笔记(一)这本书是一位面试官告诉我的,很感谢他的指点,关于面试的详细过程,我想以后再写,当然我也意识到自己的不足,一方面是面试的技巧,还有一方面就是学习的方法.阅读这本书很享受,加上之前的积累,一些疑惑,还有一些基础的不足,在这本书里找到了归宿. 下面,一起来享受这本书的精华吧 Unix诞生与1969年,那时候我们还在闹文革吧,可一个可以改变21世纪甚至更远的未来的操作系统问世,至少现在的Linux是基于Unix的设计哲学.Unix是唯一一个在不同种类的计算机,众多厂商

Javascript Dom编程艺术(第2版)读书笔记

Javascript Dom编程艺术这本书我看的是第2版的,真心觉得这本书不错,它将DOM编程的一些基本原则,及如何让Javascript代码在浏览器不支持的情况下,或浏览器支持了Javascript但用户禁用它的情况下做到平衡退化,让最基本的操作仍能顺利完成,以及如何让结构与样式分享做到真正的渐近增强叙述得很清楚,也很容易理解接受.我也是看了这本书之后,才对代码优化,结构,行为,样式有了进一步的加深理解. Javascript Dom编程艺术(第2版)读书笔记,布布扣,bubuko.com

Javascript DOM 编程艺术读书笔记16/04/01

愚人节快乐 开始用webstorm了,随着学习深入,代码越来越长,因为不借助ide还真是挺难的 今天发现了一个严重的误区,text和textNode是完全不同的两个概念,之前没有特别注意,写代码很容易跳过createTextNode直接用parentNode.appendChild(text) 单独拎出来晒一晒,以后引以为戒 Javascript DOM 编程艺术读书笔记16/04/01