23种设计模式详解:chenmingyu.top/design/html
本文源码:github.com/mingyuHub/d…java
抽象工厂模式属于建立型模式git
定义:为建立一组相关或相互依赖的对象提供一个接口,并且无须指定它们的具体类github
抽象工厂模式是对工厂方法模式的扩展,抽象工厂比工厂模式更为抽象,工厂方法模式针对产品等级结构,而抽象工厂针对产品族。算法
产品族与产品等级结构的概念:编程
产品族,是指位于不一样产品等级结构中,功能相关联的产品组成的家族,好比游戏工厂生产射击类和塔防类两种产品,任天堂的射击类游戏和塔防类游戏为一个产品族,腾讯的射击类游戏和塔防类游戏为一个产品族设计模式
产品等级结构,一个产品族由多个产品等级结构组成,射击类游戏是一个产品等级结构,塔防类游戏也是一个产品等级结构数据结构
以游戏为例,定义一个抽象工厂,生产射击和塔防两种游戏,有两个具体的生产工厂,任天堂和腾讯,两个工厂生产各自品牌的两类游戏产品ide
角色:性能
GameFactory
,规定了生成射击类和塔防类两种游戏NintendoGameFactory
,TencentGameFactory
,负责生产各自品牌的射击类和塔防类游戏Gameable
,ShootGame
和TowerDefenceGame
是抽象类,实现Gameable
NintendoShootGame
,NintendoTowerDefenceGame
,TencentShootGame
,TencentTowerDefenceGame
不易增长新的产品,若是要增长新的产品须要抽象工厂和全部具体工厂
抽象工厂,规定了生产射击和塔防两类游戏
/** * @author: chenmingyu * @date: 2019/2/14 11:29 * @description: 工厂类 */
public interface GameFactory {
/** * 建立射击游戏 * @return */
Gameable createShootGame();
/** * 建立塔防游戏 * @return */
Gameable createTowerDefenceGame();
}
复制代码
具体工厂,负责生产任天堂的射击类和塔防类游戏
/** * @author: chenmingyu * @date: 2019/2/14 18:20 * @description: 任天堂游戏制造厂 */
public class NintendoGameFactory implements GameFactory{
@Override
public Gameable createShootGame() {
return new NintendoShootGame();
}
@Override
public Gameable createTowerDefenceGame() {
return new NintendoTowerDefenceGame();
}
}
复制代码
具体工厂,负责生产腾讯的射击类和塔防类游戏
/** * @author: chenmingyu * @date: 2019/2/14 18:20 * @description: 腾讯游戏制造厂 */
public class TencentGameFactory implements GameFactory {
@Override
public Gameable createShootGame() {
return new TencentShootGame();
}
@Override
public Gameable createTowerDefenceGame() {
return new TencentTowerDefenceGame();
}
}
复制代码
抽象产品,全部游戏产品均实现该接口
/** * @author: chenmingyu * @date: 2019/2/14 11:19 * @description: 游戏接口 */
public interface Gameable {
/** * 校验帐户信息 * @param nickName */
void validateAccount(String nickName);
/** * 游戏类型 */
void getGameType();
}
复制代码
抽象类,实现Gameable接口
/** * @auther: chenmingyu * @date: 2019/2/14 11:26 * @description: 射击类游戏 */
public abstract class ShootGame implements Gameable{
@Override
public void validateAccount(String nickName) {
System.out.println("射击游戏校验昵称:"+nickName);
}
}
复制代码
/** * @auther: chenmingyu * @date: 2019/2/14 11:28 * @description: 塔防类游戏 */
public abstract class TowerDefenceGame implements Gameable{
@Override
public void validateAccount(String nickName) {
System.out.println("塔防游戏校验昵称:"+nickName);
}
}
复制代码
共四款游戏产品:NintendoShootGame
,NintendoTowerDefenceGame
,TencentShootGame
,TencentTowerDefenceGame
/** * @author: chenmingyu * @date: 2019/2/15 16:57 * @description: 任天堂射击游戏 */
public class NintendoShootGame extends ShootGame{
@Override
public void getGameType() {
System.out.println("任天堂射击游戏");
}
}
复制代码
/** * @author: chenmingyu * @date: 2019/2/15 17:18 * @description: 任天堂塔防游戏 */
public class NintendoTowerDefenceGame extends TowerDefenceGame{
@Override
public void getGameType() {
System.out.println("任天堂塔防游戏");
}
}
复制代码
/** * @author: chenmingyu * @date: 2019/2/15 16:55 * @description: 腾讯射击游戏 */
public class TencentShootGame extends ShootGame {
@Override
public void getGameType() {
System.out.println("腾讯射击游戏");
}
}
复制代码
/** * @author: chenmingyu * @date: 2019/2/15 17:17 * @description: 腾讯塔防游戏 */
public class TencentTowerDefenceGame extends TowerDefenceGame{
@Override
public void getGameType() {
System.out.println("腾讯塔防游戏");
}
}
复制代码
public static void main(String[] args) throws Exception{
NintendoGameFactory nintendoGameFactory = new NintendoGameFactory();
nintendoGameFactory.createShootGame().getGameType();
nintendoGameFactory.createTowerDefenceGame().getGameType();
TencentGameFactory tencentGameFactory = new TencentGameFactory();
tencentGameFactory.createShootGame().getGameType();
tencentGameFactory.createTowerDefenceGame().getGameType();
}
复制代码
输出
任天堂射击游戏
任天堂塔防游戏
腾讯射击游戏
腾讯塔防游戏
复制代码
菜鸟教程:www.runoob.com/design-patt…
图说设计模式:design-patterns.readthedocs.io/zh_CN/lates…
建立型设计模式
关注于如何建立对象
保证在程序运行期间一个类只有一个实例,并提供一个全局访问点
用工厂方法代替new操做,让子类去决定实例化哪一个类,工厂方法将一个类的实例化延迟到子类
抽象工厂模式属于建立型模式,是对工厂方法模式的扩展,抽象工厂比工厂模式更为抽象,工厂方法模式针对产品等级结构,而抽象工厂针对产品族
经过克隆一个已经存在的对象实例来返回新的实例,而不是经过new去建立对象
经过克隆一个已经存在的对象实例来返回新的实例,而不是经过new去建立对象
结构型设计模式
关注于类和对象之间的关系
组合两个不相干类,在两个不兼容的接口之间提供一个混合接口,使其兼容适配
将抽象部分与它的实现部分分离,使它们均可以独立地变化。桥接模式将系统各维度抽象出来,各维度独立变化,以后可经过聚合,将各维度组合起来,减小它们之间耦合
用来描述部分与总体的关系,是用于把一组类似的对象看成一个单一的对象。组合模式依据树形结构来组合对象,因此组合模式的使用场景就是出现树形结构的地方。
装饰器模式能够为一个现有的类增长新功能,又不改变其结构,要求装饰类和被装饰类实现同一个接口,装饰类持有被装饰类的实例
外观模式是为了解决类与类之家的责任关系和依赖关系的,经过提供一个Facade类来隐藏这些复杂的类之间关系的调用,并提供一个接口,供外部调用,利用这种方式进行类之间的解耦
代理模式就是在操做原对象的时候,多出来一个代理类,用来对原对象的访问进行控制和替代原对象进行一些操做
运用共享技术有效地支持大量细粒度对象的复用,主要用来减小对象的建立,用来减小内存和提升性能,比较常见的链接池,缓冲池这类的池技术都是享元模式
行为型设计模式
关注于对象之间的通讯
在父类(抽象类)中定义好算法的流程,提供抽象方法,针对不一样的实现交由不一样的子类去实现,经过这种方式将公共代码提取出来封装在父类中,而后父类去控制行为,子类负责实现
在系统中提供一组策略,并将每一个策略封装成类,使他们能够相互转换,具体策略的选择由客户端决定
定义对象间一种一对多的依赖关系,使得每当一个对象改变状态,则全部依赖于它的对象都会获得通知并被自动更新
迭代器模式就是为解决遍历元素而诞生的,它提供一种方法访问一个容器对象中各个元素,而又不需暴露该对象的内部细节
使多个对象都有机会处理请求,从而避免了请求的发送者和接受者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有对象处理它为止
将一个请求封装成一个对象,从而让你使用不一样的请求把客户端参数化,对请求排队或者记录请求日志,能够提供命令的撤销和恢复功能,用来下降类之间解耦
在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象以外保存这个状态。这样之后就可将该对象恢复到原先保存的状态,其实就是在某个时刻备份了对象的状态,在更改对象状态后,能够经过备份将对象还原成备份时刻的状态
容许一个对象在其内部状态改变时改变它的行为,对象看起来彷佛修改了它的类,对象的行为依赖于它的状态(属性),而且能够根据它的状态改变而改变它的相关行为
封装一些做用于某种数据结构中的各元素的操做,它能够在不改变数据结构的前提下定义做用于这些元素的新的操做,访问者模式就是将数据结构与数据操做相分离
用一个中介对象来封装一系列的对象交互,中介者使各对象不须要显式地相互引用,从而使其耦合松散,并且能够独立地改变它们之间的交互
给定一门语言,定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子