工厂模式
简单工厂模式
基本概念
简单工厂模式属于类的创建型模式,又叫做静态工厂方法模式。通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。
有一个工厂类,专门生产别的类的实例,这些能被他生产的类具有相同的父类!
核心思想是用一个工厂来根据输入的条件产生不同的类,然后根据不同类的virtual函数得到不同的结果。
注意:简单工厂模式不属于23种设计模式之一
角色及职责
工厂(Creator)角色
简单工厂模式的核心,它负责实现所有实例的内部逻辑。工厂类可以被外界直接调用,创建所需的产品对象。抽象(Product)角色
简单工厂模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。具体产品(Concrete Product)角色
简单工厂模式所创建的具体实例对象
优缺点
在这个模式中,工厂类是整个模式的关键所在。它包含必要的判断逻辑,能够根据外界给定的信息,决定究竟应该创建哪个具体类的对象。用户在使用时可以直接根据工厂类去创建所需的实例,而无需了解这些对象是如何创建以及如何组织的。有利于整个软件体系结构的优化。
简单工厂模式的缺点也正体现在其工厂类上,由于工厂类集中了所有实例的创建逻辑,所以“高内聚”方面做的并不好。另外,当系统中的具体产品类不断增多时,可能会出现要求工厂类也要做相应的修改,扩展性并不很好。
优点: 适用于不同情况创建不同的类时
缺点: 客户端必须要知道基类和工厂类,耦合性差 增加一个产品,需要修改工厂类
案例
#include <iostream>
using namespace std;
class Fruit
{
public:
virtual void getFruit() = 0;
protected:
private:
};
class Banana : public Fruit
{
public:
virtual void getFruit()
{
cout << "我是香蕉...." << endl;
}
protected:
private:
};
class Apple : public Fruit
{
public:
virtual void getFruit()
{
cout << "我是苹果...." << endl;
}
protected:
private:
};
class Factory
{
public:
Fruit *create(char *p)
{
if (strcmp(p, "banana") == 0)
{
return new Banana;
}
else if (strcmp(p, "apple") == 0)
{
return new Apple;
}
else
{
printf("不支持\n" ) ;
return NULL;
}
}
};
void main()
{
Factory *f = new Factory;
Fruit *fruit = NULL;
//工厂生产 香蕉
fruit = f->create("banana");
fruit->getFruit();
delete fruit;
fruit = f->create("apple");
fruit->getFruit();
delete fruit;
delete f;
cout<<"hello..."<<endl;
system("pause");
return ;
}
工厂模式
基本概念
工厂方法模式同样属于类的创建型模式又被称为多态工厂模式 。工厂方法模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中。
核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色,仅负责具体工厂子类必须实现的接口,这样进一步抽象化的好处是使得工厂方法模式可以使系统在不修改具体工厂角色的情况下引进新的产品。
角色及职责
抽象工厂(Creator)角色
工厂方法模式的核心,里面有创建各个产品的接口,返回值是抽象产品类的指针,任何工厂类都必须实现这个接口。具体工厂( Concrete Creator)角色
具体工厂类是抽象工厂的一个实现,负责实例化产品对象。抽象产品(Product)角色
工厂方法模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。具体产品(Concrete Product)角色
工厂方法模式所创建的具体实例对象
案例
#include <iostream>
using namespace std;
class Fruit
{
public:
virtual void sayname() = 0;
};
class Banana : public Fruit
{
public:
void sayname()
{
cout << "我是香蕉" << endl;
}
};
class Apple : public Fruit
{
public:
void sayname()
{
cout << "我是 Apple" << endl;
}
};
class AbFactory
{
public:
virtual Fruit *CreateProduct() = 0;
};
class BananaFactory :public AbFactory
{
public:
virtual Fruit *CreateProduct()
{
return new Banana;
}
};
class AppleFactory :public AbFactory
{
public:
virtual Fruit *CreateProduct()
{
return new Apple;
}
};
//////////////////////////////////////////////////////////////////////////
//添加新的产品
class Pear : public Fruit
{
public:
virtual void sayname()
{
cout << "我是 pear" << endl;
}
protected:
private:
};
class PearFactory : public AbFactory
{
public:
virtual Fruit *CreateProduct()
{
return new Pear;
}
};
void main()
{
AbFactory *factory = NULL;
Fruit *fruit = NULL;
//吃 香蕉
factory = new BananaFactory;
fruit = factory->CreateProduct();
fruit->sayname();
delete fruit;
delete factory;
//Pear
factory = new PearFactory;
fruit = factory->CreateProduct();
fruit->sayname();
delete fruit;
delete factory;
cout<<"hello..."<<endl;
system("pause");
return ;
}
工厂模式和简单工厂模式的比较
工厂方法模式与简单工厂模式在结构上的不同不是很明显。工厂方法类的核心是一个抽象工厂类,而简单工厂模式把核心放在一个具体类上。
工厂方法模式之所以有一个别名叫多态性工厂模式是因为具体工厂类都有共同的接口,或者有共同的抽象父类。
当系统扩展需要添加新的产品对象时,仅仅需要添加一个具体产品类以及一个具体工厂类,原有工厂的类和对象不需要进行任何修改,也不需要修改客户端,很好的符合了“开放-封闭”原则。而简单工厂模式在添加新产品类后不得不修改核心工厂方法,扩展性不好。工厂方法模式退化后可以演变成简单工厂模式。
“开放-封闭”通过添加代码的方式,不是通过修改代码的方式完成功能的增强。