《Head First 设计模式》笔记

1,策略模式

定义了算法族,分别封装起来,让他们之间可以互相替换,此模式让算法的变化独立于使用算法的客户。

oo基础:抽象,封装,多态,继承

oo原则:封装变化,多用组合,少用继承,针对接口编程,不针对实现编程

oo模式:策略模式。

2,观察者模式(Observer)

定义了对象之间的一对多依赖,这样一来,当一个对象改变状态时,他的所有依赖者都会收到通知并自动更新。

优点:松耦合

00基础:抽象

00原则:封装变化,多用组合,少用继承,针对接口编程,不针对实现编程,为交互对象之间的松耦合设计而努力,

00模式:观察者模式

3,装饰者模式

开放-关闭原则:类应该对扩展开放,对修改关闭。

装饰着和被装饰着对象有想通的超类型。

你可以用一个或者多个装饰着包装一个对象。

既然装饰着和被装饰对象有想通的超类型,所以在任何需要原始对象(被包装的)的场合,可以用装饰过的对象替代它。

装饰着可以在所委托被装饰着的行为之前与/或之后,加上自己的行为,以达到特定的目的。

对象可以在任何时候被装饰,所以可以在运行时态的,不限量的用你喜欢的装饰着来装饰对象。

装饰着模式:动态的将责任附加在对象上,若要扩展功能,装饰者提供了比继承更有弹性的替代方案。

继承是有了正确的类型,而不是继承它的行为,行为来自装饰者和基础组件,或与其他装饰者之间的组合关系。

例子:java的I/O流就是采用装饰者模式

00原则:封装变化,多用组合,少用继承,针对接口编程,不针对实现编程,为交互对象之间的松耦合设计而努力,对扩展开放,对修改关闭

4,工厂方法模式

定义了一个创建对象的接口,但由子类决定要实例化的类是哪一个,工厂方法让类把实例化推迟到子类。

简单工厂与工厂方法的区别:简单工厂把全部的事情,在一个方法都处理完了,然而工厂方法却是创建一个框架,让子类决定要如何实现。

优点:将创建对象的代码集中在一个对象或者方法中,可以避免代码中的重复,并且更方便以后的维护,这也意味着客户在实例化对象时,只会依赖于接口,而不是具体类,让代码更具有弹性。

依赖倒置原则:要依赖抽象,不要依赖具体类。

变量不可以持有具体类的引用。不要让类派生自具体类。不要覆盖基类中已实现的方法。

4.1,抽象工厂模式(不懂)

提供一个接口,用于创建相关或者依赖对象的家族,而不需要明确指定具体类。

工厂方法与抽象工厂区别:都是为了创建对象。工厂方法用的方法是继承,抽象用的是对象组合。工厂方法创建对象需要扩展一个类,并覆盖它的工厂方法。通过子类来创建对象。抽象工厂提供一个用来创建一个产品家族的抽象类型,这个类型的子类定义了产品被产生的方法,要想使用这个工厂必须先实例化它,然后将它传入一些针对抽象类型所写的代码中。

5,单件模式

确保一个类只有一个实例,并提供一个全局访问点。

多线程问题是那种解决方法:

(1)同步getInstance()方法

(2)使用急切创建实例

(3)双重检查加锁

6,命令模式

将“请求”封装成对象,以便使用不同的请求,队列或者日志来参数化其他对象,命令模式也支持可撤销的操作。

命令模式的用途:队列请求,日志请求,

7,适配器模式

将一个类的接口,转换成客户期望的另一个接口,适配器让原本接口不可兼容的类可以合作无间。

适配器分为两种:对象适配器(组合)和类适配器(继承)

7.1外观模式

提供了一个统一的接口,用来访问子系统中的一群接口,外观定义了一个高层接口,让子系统更容易使用(让接口更简单)。

外观模式并没有封装子系统,如有需要还是可以直接访问子系统的接口。

外观不只是简化了接口,也将客户从组件的子系统中解耦。

外观和适配器可以包装许多类,但是外观的意图是简化接口,而适配器的意图是将接口转换成不同接口

最少知识原则:只和你的密友谈话。

8,模板方法模式

在一个方法中定义一个算法的骨架,而将一些步骤延迟到子类中,模板方法使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤。

用途:排序,数组的排序就采用了模板方法模式,InputStream类的一个read()方法也是模板方法模式

9,迭代器模式

提供一种方法顺序访问一个聚合对象的各个元素,而又不暴露其内部的表示。

9.1组合模式(没懂)

允许你将对象组合成树形结构来表现“整体/部分”层次结构,组合能让客户以一直的方式处理个别对象以及对象组合。

10,状态模式

允许对象在内部状态改变时改变它的行为,对象看起来好像修改了它的类。

11,代理模式

为另一个对象提供一个替身或者占位符以控制对这个对象的访问。

使用代理模式创建代表对象,让代表对象控制某对象的访问,被代理的对象可以是远程的对象,创建开销大的对象或需要安全控制的对象。

11.1远程代理

远程代理可以作为另一个JVM上对象的本地代表,调用代理的方法,会被代理利用网络转发到远程执行,并且结果会通过网络返回给代理,再由代理将结果转给客户。(理解:就像驻场代表,传达客户与自己公司的意思。)

11.2 虚拟代理

虚拟代理作为创建开销大的对象的代表,虚拟代理经常直到我们真正需要一个对象的时候才创建它,当对象在创建钱和创建中时,由虚拟代理来扮演对象的替身,对象创建后,代理就会将请求直接委托给对象。

11.3动态代理

动态代理之所以称为动态,是因为运行时才将它的类创建出来,代码开始执行时,还没有proxy类,它是根据需要从你传入的接口集创建的。

InvocationHandler不是代理类,只是帮助proxy的类。

代理类有一个静态方法,叫做isProxyClass(),这个方法的返回值如果是true,就表示这是一个动态代理类。

11.4防火墙代理

控制网络资源的访问,保护主题免于“坏客户”的侵害。

11.5只能引用代理

当主题被引用时,进行额外的动作,例如计算一个对象呗引用次数。

11.6缓存代理

为开销大的运算结果提供暂时储存,它也允许多个客户共享结果,以减少计算或网络延迟。

11.7同步代理

在多线程的情况下为主题提供安全的访问。

11.8复杂隐藏代理

用来隐藏一个类的复杂几个的复杂度,并进行访问控制,

11.9写入时复制代理

用来控制对象的复制,方法是延迟对象的复制,知道客户真的需要为止。

12复合模式

复合模式结合两个或以上的模式,组成一个解决方案,解决一再发生的一般性问题。

MVC是复合模式,结合了观察者模式,策略模式和组合模式。

模型使用观察者模式,以便观察者更新,同事保持两者之间的解耦。

控制器是视图的策略,视图可以使用不用的控制器实现,得到不同的行为。

视图使用组合模式实现用户界面,用户界面通常组合了嵌套的组件,像面板,框架和按钮。

适配器模式用来将新模型适配成已有的视图和控制器。

13

模式是在某情景下,针对某问题的某种解决方案。

14其他模式

14.1桥接模式

猜你喜欢

转载自blog.csdn.net/hq091117/article/details/81237339