设计模式(1)——抽象工厂 AbstractFactory

24 篇文章 0 订阅
24 篇文章 3 订阅
目录:

设计模式学习笔记首页
设计模式(1)——抽象工厂 AbstractFactory
设计模式(2)——生成器 Builder
设计模式(3)——工厂方法 Factory Method
设计模式(4)——原型 Prototype
设计模式(5)——单例 Singleton
设计模式(6)——适配器 Adapter
设计模式(7)——桥接 Bridge
设计模式(8)——组合 Composite
设计模式(9)——装饰 Decorator
设计模式(10)——外观 Facade
设计模式(11)——享元 Flyweight
设计模式(12)——代理 Proxy
设计模式(13)——职责链 Chain Of Responsibility
设计模式(14)——命令 Command
设计模式(15)——解释器 Interpreter
设计模式(16)——迭代器 Iterator
设计模式(17)——中介者 Mediator
设计模式(18)——备忘录 Memento
设计模式(19)——观察者 Observer
设计模式(20)——状态 State
设计模式(21)——策略 Strategy
设计模式(22)——模板方法 Template Method
设计模式(23)——访问者 Visitor

一、Abstract Factory (抽象工厂,对象创建型模式)

1. 问题:

  AbstractFactory(抽象工厂)用来创建一类(或称一种)产品(具体对象),当对 Facotry 类进行抽象,然后不同种类的工厂做为子类时,就成为 AbastractFactory 模式。

2. 功能:

  创建不同种类(一组)具体对象。一个具体工厂(一个AbstractFacotry的具体子类)生产一组具体产品对象。所以多个具体工厂就会生产多组具体产品对象。

3. 意图:

  封装一组对象的创建过程,让系统与具体对象解耦。

4. 类图:

在这里插入图片描述

5. 抽象工厂与工厂方法的区别:

  工厂方法生产一种单一产品,抽象工厂生产一组(有多种)产品。

6. C++实现

AbstractFactory.h
// AbstractFactory.h
#pragma once

class AbstractProductA;
class AbstractProductB;

class AbstracFactory
{
public:	
	virtual ~AbstracFactory();
	virtual AbstractProductA* CreateProductA() = 0;
	virtual AbstractProductB* CreateProductB() = 0;

protected:
	AbstracFactory();

private:

};

class ConcreteFactory1 : public AbstracFactory {
public:
	ConcreteFactory1();
	~ConcreteFactory1();
	AbstractProductA* CreateProductA();
	AbstractProductB* CreateProductB();
protected:
private:
};

class ConcreteFactory2 : public AbstracFactory {
public:
	ConcreteFactory2();
	~ConcreteFactory2();
	AbstractProductA* CreateProductA();
	AbstractProductB* CreateProductB();
protected:
private:
};

AbstractFactory.cpp
// AbstractFactory.cpp
#include "AbstractFactory.h"
#include "Product.h"

#include <iostream>

using namespace std;

AbstracFactory::AbstracFactory() {}
AbstracFactory::~AbstracFactory() {}
ConcreteFactory1::ConcreteFactory1() {}
ConcreteFactory1::~ConcreteFactory1() {}
ConcreteFactory2::ConcreteFactory2() {}
ConcreteFactory2::~ConcreteFactory2() {}

AbstractProductA* ConcreteFactory1::CreateProductA() {
	return new ProductA1();
}

AbstractProductB* ConcreteFactory1::CreateProductB() {
	return new ProductB1();
}

AbstractProductA* ConcreteFactory2::CreateProductA(){
	return new ProductA2();
}

AbstractProductB* ConcreteFactory2::CreateProductB() {
	return new ProductB2();
}
Product.h
// Product.h
#pragma once

class AbstractProductA {
public:
	virtual ~AbstractProductA();
protected:
	AbstractProductA();
private:
};

class AbstractProductB {
public:
	virtual ~AbstractProductB();
protected:
	AbstractProductB();
private:
};

class ProductA1 : public AbstractProductA {
public:
	ProductA1();
	~ProductA1();
protected:
private:
};

class ProductA2 : public AbstractProductA {
public:
	ProductA2();
	~ProductA2();
protected:
private:
};

class ProductB1 : public AbstractProductB {
public:
	ProductB1();
	~ProductB1();
protected:
private:
};

class ProductB2 : public AbstractProductB {
public:
	ProductB2();
	~ProductB2();
protected:
private:
};
Product.cpp
//Product.cpp
#include "Product.h"
#include <iostream>
using namespace std;

AbstractProductA::AbstractProductA() {}
AbstractProductA::~AbstractProductA(){}
AbstractProductB::AbstractProductB() {}
AbstractProductB::~AbstractProductB(){}

ProductA1::ProductA1() {
	cout << "ProductA1" << endl;
}
ProductA1::~ProductA1() { }

ProductA2::ProductA2() {
	cout << "ProductA2" << endl;
}
ProductA2::~ProductA2() { }

ProductB1::ProductB1() {
	cout << "ProductB1" << endl;
}
ProductB1::~ProductB1() {}

ProductB2::ProductB2() {
	cout << "ProductB2" << endl;
}
ProductB2::~ProductB2() {}
main.cpp
// main.cpp
#include "AbstractFactory.h"

#include <iostream>

using namespace std;

int main(int argc, char* argv[]) {
	AbstracFactory* f1 = new ConcreteFactory1();
	f1->CreateProductA();
	f1->CreateProductB();

	AbstracFactory* f2 = new ConcreteFactory2();
	f2->CreateProductA();
	f2->CreateProductB();

	return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值