zoukankan      html  css  js  c++  java
  • 2015-03-13---抽象工厂(附代码),

    原谅博主吧,这两天可能要比較忙啊,当然不是忙程序的了,过了这阵子就好了吧。详细的就不说了。今天就值简单的说一个抽象工厂模式吧。

    在前一阵子我们写过了简单工厂,和工厂方法模式,这个抽象工厂是基于这两种更加的抽象,简单工厂就不说了。工厂方法模式里,我们工厂仅仅能造一个产品。这个抽象工厂是能够造非常多种产品,每个产品有自己的抽象类,上图:

    这个图看着连线挺多的,事实上仅仅只是是类多一点。这个AbstractFactory就是这个抽象工厂,这个抽象工厂眼下能够造出两种抽象产品各自是AbstractProductA。和AbstractProductB,总的来说就是这么多, client在调用的时候仅仅须要。依据什么工厂就调用什么即可了。以下是我写的代码:

    #include <iostream>
    
    using namespace std;
    
    class AbstractProductB;
    class AbstractProductA;
    class AbstractFactory;
    
    class AbstractFactory
    {
    public:
    	virtual AbstractProductA * createProductA() = 0;
    	virtual AbstractProductB * createProductB() = 0;
    };
    
    class AbstractProductA
    {
    public:
    	virtual void printA() = 0;
    };
    
    class ProductA1 : public AbstractProductA
    {
    public:
    	virtual void printA()
    	{
    		cout << "i am a1" << endl;
    	}
    };
    
    class ProductA2 : public AbstractProductA
    {
    public:
    	virtual void printA()
    	{
    		cout << "i am a2" << endl;
    	}
    };
    
    class AbstractProductB
    {
    public:
    	virtual void printB() = 0;
    };
    
    class ProductB1 : public AbstractProductB
    {
    public:
    	virtual void printB()
    	{
    		cout << "i im b1" << endl;
    	}
    };
    
    class ProductB2 : public AbstractProductB
    {
    public:
    	virtual void printB()
    	{
    		cout << "i im b2" << endl;
    	}
    };
    
    class ConcreteFactory1 : public AbstractFactory
    {
    public:
    	virtual AbstractProductA * createProductA()
    	{
    		return new ProductA1;
    	}
    	virtual AbstractProductB * createProductB()
    	{
    		return new ProductB1;
    	}
    };
    
    class ConcreteFactory2 : public AbstractFactory
    {
    public:
    	virtual AbstractProductA * createProductA()
    	{
    		return new ProductA2;
    	}
    	virtual AbstractProductB * createProductB()
    	{
    		return new ProductB2;
    	}
    };
    
    
    void main()
    {
    	{
    		AbstractFactory *fac = new ConcreteFactory1;
    		AbstractProductA *pa = fac->createProductA();
    		AbstractProductB *pb = fac->createProductB();
    		pa->printA();
    		pb->printB();
    	}
    	{
    		AbstractFactory *fac = new ConcreteFactory2;
    		AbstractProductA *pa = fac->createProductA();
    		AbstractProductB *pb = fac->createProductB();
    		pa->printA();
    		pb->printB();
    	}
    	cin.get();
    }
    这个就是我实现的了,大家能够看一下。


    抽象工厂的超出便是易于交换产品系列。他仅仅须要改变详细工厂就可以使用不同的产品配置。
    第二优点就是他让详细的创建演示样例的过程与client分离,client是通过他们的抽象接口操纵实例。

    只是不好的地方就在于每一次都new。这样程序假设大起来的须要替换就会麻烦。

    我我们就能够用反射+抽象工厂的数据訪问程序。用反射来替换简单工厂的switch


    今天搞了半天还是没有搞定github托管代码的东西,哎,英文不好就是淡疼啊,尽管曾经公司用git,可是这个还是有那么一点差别的。主要是同步倒是同步上去了。可是有一些项目总会同步到一般就断。


    今天就忙到这里吧,今天已经刷完牙了。明天还要早起,可能这两天编程的东西会少一点,没办法啊,过了这阵子就好了。


  • 相关阅读:
    P7003 [NEERC2013]Hack Protection
    P6753 [BalticOI 2013 Day1] Ball Machine
    笛卡尔树-P2659 美丽的序列
    [省选联考 2020 A/B 卷] 冰火战士
    CF1166E The LCMs Must be Large
    线段树标记永久化模板
    zoj 2112 单点修改的主席树(树状数组套主席树)
    poj 2104 无修改主席树
    python中map的排序以及取出map中取最大最小值
    python之禅
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/5062415.html
Copyright © 2011-2022 走看看