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,可是这个还是有那么一点差别的。主要是同步倒是同步上去了。可是有一些项目总会同步到一般就断。


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


  • 相关阅读:
    二十四种设计模式:观察者模式(Observer Pattern)
    二十四种设计模式:工厂方法模式(Factory Method Pattern)
    Java迷题:等于,还是不等于?
    UCenter创始人、Discuz!创始人、管理员账号的认知(转)
    Internet Explorer 无法启用 JavaScript 怎么办?
    IIS配置PHP环境(快速最新版)(转载+自创)
    零基础学php的自学
    PHP实体层基础类
    PHP数据库链接类(PDO+Access)
    C# Memcached 缓存
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/5062415.html
Copyright © 2011-2022 走看看