工厂方法模式对简单工厂模式进行了抽象。有一个抽象的Factory类(可以是抽象类和接口),这个类将不再负责具体的产品生产,而是只制定一些规范,具体的生产工作由其子类去完成。在这个模式中,工厂类和产品类往往可以依次对应。即一个抽象工厂对应一个抽象产品,一个具体工厂对应一个具体产品,这个具体的工厂就负责生产对应的产品。
上面的图是我随便画的,有点乱。UML的画法如下:
factoryMoth.h文件内容如下:
#ifndef __factoryMoth
#define __factoryMoth
#include <iostream>
using namespace std;
//抽象产品
class Factory_Communication//抽象仪表接口
{
public:
virtual void Get_Instrument_Data()=0;
};
//具体产品
class communication_Moth_A9 : public Factory_Communication//具体仪表
{
public:
void Get_Instrument_Data()
{
cout << "正在接收XK3190仪表数据" << endl;
}
};
class communication_Moth_DS1 : public Factory_Communication//具体仪表
{
public:
void Get_Instrument_Data()
{
cout << "正在接收DS1仪表数据" << endl;
}
};
//抽象工厂
class Factory_Software_UI //软件界面接口
{
public:
virtual Factory_Communication * Factory_Instrument()=0;//仪表通信需求
};
//具体工厂,每一个具体工厂对应一种具体产品
class Select_UI_A9 : public Factory_Software_UI //界面具体选择
{
public:
Factory_Communication * Factory_Instrument()//返回抽象仪表
{
cout << "您选择了XK3190A9型号" << endl;
return new communication_Moth_A9;//具体仪表对象
}
};
//具体工厂,每一个具体工厂对应一种具体产品
class Select_UI_DS1 : public Factory_Software_UI //界面具体选择
{
public:
Factory_Communication * Factory_Instrument()//返回抽象仪表
{
cout << "您选择了DS1型号" << endl;
return new communication_Moth_DS1;//具体仪表对象
}
};
#endif
.cpp文件调用方法如下:
#include <iostream>
#include "factorymoth.h"
using namespace std;
int main(int argc, char *argv[])
{
//用户只需要面向工厂,选择了工厂,也就相当于选择了产品.
//(1)抽象工厂指针=具体工厂指针
Factory_Software_UI * mySelect = new Select_UI_A9;
//(2)抽象产品指针=具体工厂方法实例化产品指针
Factory_Communication *p = mySelect->Factory_Instrument();
//(3)生产具体产品
p->Get_Instrument_Data();
//--------------------------------------------------------------
Factory_Software_UI * mySelect1 = new Select_UI_DS1;
//(2)抽象产品指针=具体工厂方法实例化产品指针
Factory_Communication *p1 = mySelect1->Factory_Instrument();
//(3)生产具体产品
p1->Get_Instrument_Data();
return 0;
}
使用工厂方法时,用户只需要选择某种工厂就可以了,因为一个工厂对应一种具体产品。第(2)、(3)步都是一样的,这样维护时,代码修改量会减小。