设计模式之十一:抽象工厂模式(Abstract Factory)
抽象工厂模式:
提供了一个创建一系列相关的或相互依赖的对象的接口而不须要详细指定它们的类型。
Provide an interface for creating families of related or dependent objects without specifying their concrete classes.
UML类图:
主要包含:
- AbstractFactory(ContinentFactory):抽象的工厂类。为详细的工厂类声明了一系列的接口。
- ConcreteFactory(AfricaFactory,AmericaFactory):详细的工厂类。实现了创建详细对象的接口。
- AbstractProduct(Herbivore,Carnivore):抽象的产品类。
- Product(Wildebeest,Lion,Bison,Wolf):详细的产品类
- Client(AnimalWorld):使用抽象的工厂和抽象的产品类来创建对象。
主要的抽象工厂模式C++代码例如以下:
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
class AbstractProductA
{
public:
virtual void show()=0;
};
class ProductA1:public AbstractProductA
{
public:
void show()
{
std::cout<<"ProductA1::show()"<<std::endl;
}
};
class ProductA2:public AbstractProductA
{
public:
void show()
{
std::cout<<"ProductA2::show()"<<std::endl;
}
};
class AbstractProductB
{
public :
virtual void display()=0;
};
class ProductB1:public AbstractProductB
{
public:
void display()
{
std::cout<<"ProductB1::display()"<<std::endl;
}
};
class ProductB2:public AbstractProductB
{
public:
void display()
{
std::cout<<"ProductB2::display()"<<std::endl;
}
};
class AbstractFactory
{
public:
virtual AbstractProductA* createProductA()=0;
virtual AbstractProductB* createProductB()=0;
};
class ConcreteFactory1:public AbstractFactory
{
public:
AbstractProductA *createProductA()
{
return new ProductA1();
}
AbstractProductB *createProductB()
{
return new ProductB1();
}
};
class ConcreteFactory2:public AbstractFactory
{
public:
AbstractProductA *createProductA()
{
return new ProductA2();
}
AbstractProductB *createProductB()
{
return new ProductB2();
}
};
class Client
{
public:
Client()
{
}
Client(AbstractFactory *af)
{
abstractFactory=af;
}
AbstractProductA * getProductA()
{
return abstractProductA;
}
AbstractProductB* getProductB()
{
return abstractProductB;
}
void run()
{
abstractProductA=abstractFactory->createProductA();
abstractProductB=abstractFactory->createProductB();
}
~Client()
{
if(!abstractProductA)
delete abstractProductA;
if(!abstractProductB)
delete abstractProductB;
}
private:
AbstractFactory *abstractFactory;
AbstractProductA * abstractProductA;
AbstractProductB * abstractProductB;
};
int main()
{
std::cout<<"抽象工厂模式測试"<<std::endl;
AbstractFactory *af=new ConcreteFactory1();
Client* client=new Client(af);
client->run();
client->getProductA()->show();
client->getProductB()->display();
delete af;
delete client;
return 0;
}
运行结果:
再看一个详细的样例:
- AbstractFactor为ContinentFactory,即大陆工厂。
- ConcreteFactory为AfricaFactory(非洲大陆),AmericaFacoty(美洲大陆)
- AbstractProduct包含Herbivore(食草动物)。Carnivore(食肉动物)。
- Product包含Wildebeest(羚羊),Lison(狮子)。Bison(美洲野牛),Wolf(美洲狐狸)。
- Client为AnimalWorld。
大陆上有食肉动物和食草动物,可是不同的大陆比方说非洲大陆的食肉动物和食草动物和美洲大陆的食肉动物和食草动物是不同的。抽象工厂工厂模式和工厂方法模式的不同点就在于抽象工厂模式有两处变化的地方,除了工厂类能够变化外,抽象的产品类有多个而不是一个。
UML图例如以下:
C++代码实现例如以下:
#include <stdlib.h>
#include <stdio.h>
#include <iostream>
//食草动物
class Herbivore
{
public:
virtual void drink()=0;
};
//羚羊的一种。产于非洲
class Wildebeest:public Herbivore
{
public:
void drink()
{
std::cout<<"wildbeest drink"<<std::endl;
}
};
//美洲野牛
class Bison:public Herbivore
{
public:
void drink()
{
std::cout<<"bison drink"<<std::endl;
}
};
//食肉动物
class Carnivore
{
public:
virtual void eat()=0;
};
//非洲狮子
class Lion:public Carnivore
{
public:
void eat()
{
std::cout<<"lion eat"<<std::endl;
}
};
//狼
class Wolf:public Carnivore
{
public:
void eat()
{
std::cout<<"wolf eat"<<std::endl;
}
};
//大陆工厂
class ContinentFactory
{
public:
virtual Herbivore * createHerbivore()=0;
virtual Carnivore * createCarnivore()=0;
};
class AfricaFactory :public ContinentFactory
{
public:
virtual Herbivore * createHerbivore()
{
return new Wildebeest();
}
virtual Carnivore * createCarnivore()
{
return new Lion();
}
};
class AmericaFactory :public ContinentFactory
{
public:
virtual Herbivore * createHerbivore()
{
return new Bison();
}
virtual Carnivore * createCarnivore()
{
return new Wolf();
}
};
class AnimalWorld
{
public:
AnimalWorld()
{
}
AnimalWorld(ContinentFactory *cf)
{
herbivore=cf->createHerbivore();
carnivore=cf->createCarnivore();
}
void action()
{
herbivore->drink();
carnivore->eat();
}
~AnimalWorld()
{
if(!herbivore)
delete herbivore;
if(!carnivore)
delete carnivore;
}
private:
Herbivore * herbivore;
Carnivore * carnivore;
};
int main()
{
std::cout<<"抽象工厂模式详细的样例"<<std::endl;
ContinentFactory * cf=new AmericaFactory;
AnimalWorld *an=new AnimalWorld(cf);
an->action();
delete cf;
delete an;
return 0;
}
运行结果:
设计模式之十一:抽象工厂模式(Abstract Factory)的更多相关文章
- 设计模式学习心得<抽象工厂模式 Abstract Factory>
抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他工厂.该超级工厂又称为其他工厂的工厂.这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式. 在抽 ...
- Net设计模式实例之抽象工厂模式(Abstract Factory Pattern)
一.抽象工厂模式简介(Bref Introduction) 抽象工厂模式(Abstract Factory Pattern),提供一个创建一系列相关或者相互依赖对象的接口,而无需制定他们的具体类.优点 ...
- IOS设计模式浅析之抽象工厂模式(Abstract Factory)
概述 在前面两章中,分别介绍了简单工厂模式和工厂方法模式,我们知道简单工厂模式的优点是去除了客户端与具体产品的依赖,缺点是违反了“开放-关闭原则”:工厂方法模式克服了简单工厂模式的缺点,将产品的创建工 ...
- 《JAVA设计模式》之抽象工厂模式(Abstract Factory)
场景问题 举个生活中常见的例子——组装电脑,我们在组装电脑的时候,通常需要选择一系列的配件,比如CPU.硬盘.内存.主板.电源.机箱等.为讨论使用简单点,只考虑选择CPU和主板的问题. 事实上,在选择 ...
- 乐在其中设计模式(C#) - 抽象工厂模式(Abstract Factory Pattern)
原文:乐在其中设计模式(C#) - 抽象工厂模式(Abstract Factory Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 抽象工厂模式(Abstract Factor ...
- 【设计模式】抽象工厂模式 Abstract Factory Pattern
简单工厂模式是一个工厂类根据工厂方法的参数创建不出不同的产品, 工厂方法模式是每一个产品都有一个一一对应的工厂负责创建该产品.那么今天要讲的抽象工厂模式是一个工厂能够产生关联的一系列产品.抽象工厂模式 ...
- .NET设计模式(2):1.2 抽象工厂模式(Abstract Factory)
概述 抽象工厂模式(Abstract Factory)是所有形态的工厂模式中最为抽象和最具一般性的一种形态.抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式.抽象工厂模式可以向客户端提供一个接口 ...
- 设计模式 - 抽象工厂模式(abstract factory pattern) 具体解释
抽象工厂模式(abstract factory pattern) 详细解释 本文地址: http://blog.csdn.net/caroline_wendy/article/details/2709 ...
- 二十四种设计模式:抽象工厂模式(Abstract Factory Pattern)
抽象工厂模式(Abstract Factory Pattern) 介绍提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类. 示例有Message和MessageModel,Messag ...
- 【UE4 设计模式】抽象工厂模式 Abstract Factory Pattern
概述 描述 提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类:具体的工厂负责实现具体的产品实例 抽象工厂中每个工厂可以创建多种产品(如苹果公司生产iPhone.iPad): 工厂方法 ...
随机推荐
- ssh登录服务器免密钥
我有三台Linux,IP分别为a:10.0.0.20/b:10.0.0.50/c:10.0.0.60/d:10.0.0.70 # a为本地主机 b c d为远程主机 #在a上生成密钥对(3次回车出现 ...
- Mongodb的学习整理(下)
聚合 aggregate 聚合(aggregate)主要用于计算数据,类似sql中的sum().avg() 语法 db.集合名称.aggregate([{管道:{表达式}}]) 管道 管道在Unix和 ...
- Laravel 5.5 Blade::if 简介
Laravel 5.5 引入了一个新的黑科技,就是你可以使用 Blade::if 来进行一些简单的逻辑判断啦!想不出应用场景在哪?想象下面的场景: 判断一个用户是否是 admin 判断应用的开发环境不 ...
- POJ 3225.Help with Intervals-线段树(成段替换、区间异或、简单hash)
POJ3225.Help with Intervals 这个题就是对区间的各种操作,感觉这道题写的一点意思都没有,写到后面都不想写了,而且更神奇的是,自己的编译器连结果都输不出来,但是交上就过了,也是 ...
- Java android DES+Base64加密解密
服务器与客户端加密解密传输, 中间遇到各种坑,客户端无论用AES还是DES解密时都会出现错误,后来才看到好多人说要用AES/DES加完密后还要BASE64加密,照做时发现android和java的Ba ...
- 洛谷 P3378 【模板】堆
如题,初始小根堆为空,我们需要支持以下3种操作: 操作1: 1 x 表示将x插入到堆中 操作2: 2 输出该小根堆内的最小数 操作3: 3 删除该小根堆内的最小数 输入输出格式 输入格式: 第一行包含 ...
- HDU 5915 The Fastest Runner Ms. Zhang (CCPC2016 长春 E题,分类讨论 + 求字典序最小的直径 + 数据结构寻找最小值)
题目链接 CCPC2016 Changchun Problem E 题意 给定一个$n$个点$n$条边的无向图,现在从某一点$s$出发,每个点都经过一遍,最后在$t$点停止,经过的边数为$l$ ...
- springboot静态资源映射
springboot静态资源映射 WebMvcAutoConfiguration @Override public void addResourceHandlers(ResourceHandlerRe ...
- AtCoder - 3962 Sequence Growing Hard
Problem Statement Find the number of the possible tuples of sequences (A0,A1,…,AN) that satisfy all ...
- [Lydsy1710月赛] 小B的数字
神TM 又又又又是构造题..... 很简单的化简就是,把2^k[i]都换成k[i] ,然后就可以得出 对于任意的i,k[i] * a[i] >= ∑k[]. 最优的构造肯定是使 k[i] = ...