`
kmplayer
  • 浏览: 512216 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

设计模式之工厂模式

阅读更多
特征:封装对象的创建.
1,给一个对象添加新类型时,类的创建必然要发生改变,导致了问题的出现.
2,解决办法:强制用一个通用的工厂(factory)来创建对象,而不允许将创建对象的代码遍布于整个程序.
3,如果创建对象的代码都装到这个工厂执行,那么在增加新对象时,所要做的全部工作就是只需修改工厂.
4,每个面向对象的应用程序都需要创建对象,并且因为人们可能添加新类来扩展应用程序,因此工厂模式可能是所有设计模式中最有用的模式之一.

5,工程模式的实现方法之一:在基类中定义一个静态成员函数.
实例代码:
#include <iostream>
#include <stdexcept>
#include <vector>
using namespace std;

class Shape
{
public:
    virtual void draw()=0;
    virtual void erase()=0;
    virtual ~Shape(){}
    class shape_error : public logic_error
    {
    public:
        shape_error(string type):logic_error("Cann't create shape: "+type){};
    };
    static Shape* factory(const string& type) throw(shape_error);
};

class Circle : public Shape
{
    Circle(){}//构造函数设为私有,保证只有静态工厂方法可以创建对象
    friend Shape* Shape::factory(const string& type);
public:
    void draw(){ cout<<"Circle:Draw"<<endl; }
    void erase(){ cout<<"Circle:Erase"<<endl; }
    ~Circle(){ cout<<"Circle:~Circle"<<endl; }
};

class Square : public Shape
{
    Square(){}//构造函数设为私有,保证只有静态工厂方法可以创建对象
    friend Shape* Shape::factory(const string& type);
public:
    void draw(){ cout<<"Square:Draw"<<endl; }
    void erase(){ cout<<"Square:Erase"<<endl; }
    ~Square(){ cout<<"Square:~Circle"<<endl; }
};


Shape* Shape::factory(const string& type) throw(shape_error)
{
    if(type=="Circle") return new Circle;
    if(type=="Square") return new Square;
    throw shape_error(type);
}

char* sl[] = { "Circle", "Square", "Square", "Circle", "Circle", "Circle", "Square" };
int main()
{
    vector<Shape*> shapes;
    try
    {
        for(size_t i = 0; i < sizeof sl / sizeof sl[0]; i++)
            shapes.push_back(Shape::factory(sl[i]));
    } catch(Shape::shape_error& e)
    {
        cout << e.what() << endl;
        for(vector<Shape*>::iterator ite=shapes.begin();ite!=shapes.end();ite++)
            delete *ite;
        return EXIT_FAILURE;
    }
    for(size_t i = 0; i < shapes.size(); i++)
    {
        shapes[i]->draw();
        shapes[i]->erase();
    }
    for(vector<Shape*>::iterator ite=shapes.begin();ite!=shapes.end();ite++)
        delete *ite;
    return 0;
}


6,多态工厂模式:工厂方法作为单独的类中的虚函数出现.
实例代码:
#include <iostream>
#include <stdexcept>
#include <vector>
#include <map>
using namespace std;

class Shape
{
public:
    virtual void draw()=0;
    virtual void erase()=0;
    virtual ~Shape(){}
};

class ShapeFactory //类工厂
{
    virtual Shape* create()=0; //虚函数
    static map<string,ShapeFactory*> factories;
public:
    virtual ~ShapeFactory(){}
    friend class ShapeFactoryInitializer;
    //核心方法
    class shape_error : public logic_error
    {
    public:
        shape_error(string type):logic_error("Cann't create shape: "+type){};
    };
    static Shape* createShape(const string& id) throw(shape_error)
    {
        if(factories.find(id)!=factories.end())
            return factories[id]->create();
        else
            throw shape_error(id);
    }
};
map<string,ShapeFactory*> ShapeFactory::factories;

class Circle : public Shape
{
    Circle(){}//构造函数设为私有,保证只有静态工厂方法可以创建对象
    friend class ShapeFactoryInitializer; //友元
    //注意私有友元类的使用
    class Factory;
    friend class Factory;
    class Factory : public ShapeFactory
    {
    public:
        Shape* create(){ return new Circle; }
        friend class ShapeFactoryInitializer; //友元
    };
public:
    void draw(){ cout<<"Circle:Draw"<<endl; }
    void erase(){ cout<<"Circle:Erase"<<endl; }
    ~Circle(){ cout<<"Circle:~Circle"<<endl; }
};

class Square : public Shape
{
    Square(){}//构造函数设为私有,保证只有静态工厂方法可以创建对象
    friend class ShapeFactoryInitializer; //友元
    //注意私有友元类的使用
    class Factory;
    friend class Factory;
    class Factory : public ShapeFactory
    {
    public:
        Shape* create(){ return new Square; }
        friend class ShapeFactoryInitializer; //友元
    };
public:
    void draw(){ cout<<"Square:Draw"<<endl; }
    void erase(){ cout<<"Square:Erase"<<endl; }
    ~Square(){ cout<<"Square:~Circle"<<endl; }
};

class ShapeFactoryInitializer
{
    static ShapeFactoryInitializer si;
    ShapeFactoryInitializer()
    {
        ShapeFactory::factories["Circle"]=new Circle::Factory; //这里
        ShapeFactory::factories["Square"]=new Square::Factory; //这里
    }
    ~ShapeFactoryInitializer()
    {
        for(map<string,ShapeFactory*>::iterator ite=ShapeFactory::factories.begin();ite!=ShapeFactory::factories.end();ite++)
            delete ite->second;
    }
};
ShapeFactoryInitializer ShapeFactoryInitializer::si;

char* sl[] = { "Circle", "Square", "Square", "Circle", "Circle", "Circle", "Square" };
int main()
{
    vector<Shape*> shapes;
    try
    {
        for(size_t i = 0; i < sizeof sl / sizeof sl[0]; i++)
            shapes.push_back(ShapeFactory::createShape(sl[i]));
    } catch(ShapeFactory::shape_error& e)
    {
        cout << e.what() << endl;
        for(vector<Shape*>::iterator ite=shapes.begin();ite!=shapes.end();ite++)
            delete *ite;
        return EXIT_FAILURE;
    }
    for(size_t i = 0; i < shapes.size(); i++)
    {
        shapes[i]->draw();
        shapes[i]->erase();
    }
    for(vector<Shape*>::iterator ite=shapes.begin();ite!=shapes.end();ite++)
        delete *ite;
    return 0;
}


7,抽象工厂模式:
使用若干工厂方法模式,每个工厂方法模式创建一个不同类型的对象.
#include <iostream>
using namespace std;

class Obstacle
{
public:
    virtual void action()=0;
};

class Fire : public Obstacle
{
    void action(){ cout<<"Fire."<<endl; }
};

class Water : public Obstacle
{
    void action(){ cout<<"Water."<<endl; }
};

class Player
{
public:
    virtual void interactWith(Obstacle*)=0;
};

class MM : public Player
{
public:
    void interactWith(Obstacle* ob)
    {
        cout<<"MM:";
        ob->action();
    }
};

class GG : public Player
{
public:
    void interactWith(Obstacle* ob)
    {
        cout<<"GG:";
        ob->action();
    }
};

class GameFactory
{
public:
    virtual Player* makePlayer()=0;
    virtual Obstacle* makeObstacle()=0;
};

class GGandWater : public GameFactory
{
    virtual Player* makePlayer(){ return new GG; }
    virtual Obstacle* makeObstacle(){ return new Water; }
};

class MMandFire : public GameFactory
{
    virtual Player* makePlayer(){ return new MM; }
    virtual Obstacle* makeObstacle(){ return new Fire; }
};

class CreateGame //综合管理
{
    GameFactory* gef;
    Player* p;
    Obstacle* ob;
public:
    CreateGame(GameFactory* factory) : gef(factory),p(factory->makePlayer()),ob(factory->makeObstacle()){}
    void player(){ p->interactWith(ob); }
    ~CreateGame()
    {
        delete gef;
        delete p;
        delete ob;
    }
};

int main()
{
    CreateGame g1(new GGandWater);
    g1.player();
    CreateGame g2(new MMandFire);
    g2.player();
    return 0;
}
分享到:
评论

相关推荐

    java设计模式之工厂模式

    java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式java设计模式之工厂模式...

    深入浅出设计模式之工厂模式

    根据提供的标题“深入浅出设计模式之工厂模式”与描述“将《Head First 设计模式》(中文版)按章节进行了分割,每章一个文件,方便大家下载”,我们可以推测出这部分内容主要关注的是设计模式中的工厂模式。...

    菜鸟教程设计模式之工厂模式代码整理

    在这个"菜鸟教程设计模式之工厂模式代码整理"中,我们将深入探讨工厂模式的基本概念、结构以及如何在实际编程中应用。 工厂模式的核心思想是通过一个专门的工厂类来创建对象,而不是让客户端代码直接实例化具体的...

    JAVA设计模式之工厂模式

    ### JAVA设计模式之工厂模式 #### 一、工厂模式概述 工厂模式是一种常见的设计模式,主要应用于当系统中存在大量的类实例化需求时。通过工厂模式,我们可以避免直接使用`new`关键字创建对象,而是通过工厂类来创建...

    菜鸟教程设计模式之工厂模式代码整理(反射机制改进版)

    在这个“菜鸟教程设计模式之工厂模式代码整理(反射机制改进版)”中,我们主要探讨的是如何利用Java的反射机制来进一步增强工厂模式的功能。 首先,理解工厂模式的基本概念。工厂模式属于创建型设计模式,它提供了...

    [创建型模式] head first 设计模式之工厂模式(Factory)

    工厂方法(Factory Method)是工厂模式的一种具体实现,它是《Head First 设计模式》这本书中讲解的重点之一。在这个模式中,一个工厂类声明了一个创建对象的抽象方法,但并不实现这个方法。而是由子类决定要实例化...

    JAVA设计模式之工厂模式.pdf

    JAVA设计模式之工厂模式是软件开发中一种常用的设计模式,它专门负责将大量有共同接口的类实例化。工厂模式可以动态决定将哪一个类实例化,不必事先知道每次要实例化哪一个类。 一、工厂模式的介绍 工厂模式有三种...

    Java设计模式之工厂模式(Factory)

    ### Java设计模式之工厂模式详解 #### 一、引言 设计模式是在软件设计过程中针对常见问题而提出的标准化解决方案。其中,“工厂模式”是面向对象编程中最常用的模式之一,主要目的是封装实例化过程,使代码更加...

    专题资料(2021-2022年)Java设计模式之工厂模式Factory.doc

    【Java设计模式之工厂模式Factory】是面向对象编程领域中常用的设计模式,它提供了一种创建对象的最佳方式。工厂模式的主要思想是将对象的创建过程封装起来,使得客户端(使用对象的代码)无需关心对象的具体创建...

    设计模式之工厂模式Java实现和类设计图

    在软件开发中,设计模式是经验丰富的开发者们总结出的解决常见问题的模板或最佳实践。工厂模式作为其中的一种,是对象创建型模式,它的主要目的是为了隔离对象创建过程与客户端之间的关系,使得创建过程更加灵活,...

    Java设计模式之工厂模式(Factory).doc

    Java设计模式之工厂模式(Factory).doc

Global site tag (gtag.js) - Google Analytics