自学设计模式(简单工厂模式、工厂模式、抽象工厂模式)

news/2024/7/5 3:27:52

使用工厂模式来生产某类对象(代码简化且容易维护,类之间有血缘关系,可以通过工厂类进行生产);

简单工厂模式(用于创建简单对象)

对于简单工厂模式,需要的工厂类只有一个;

在工厂类中的公共成员函数来创建所需对象;

#include <bits/stdc++.h>
using namespace std;
// 产品父类 
class shape{
public:
	virtual void cal() = 0;
	virtual ~shape(){
		
	}
}; 

class triangle:public shape{
public:
	void cal() override{
		cout<<"三角形面积";
	}
};

class square:public shape{
public:
	void cal() override{
		cout<<"正方形面积";
	}
};

class cycle:public shape{
public:
	void cal() override{
		cout<<"圆形面积";
	}
};

// 工厂类
enum class Type:char{
	triangle , 
	square , 
	cycle
};
class fac{
public:
	shape* creat_kinds(Type type){
		shape* ptr = nullptr;
		switch(type){
			case Type::triangle:
				ptr = new triangle;
				break;
			case Type::square:
				ptr = new square;
				break;
			case Type::cycle:
				ptr = new cycle;
				break;
		}
		return ptr;
	}
}; 
int main(){
	fac* cur = new fac;
	shape* obj = cur->creat_kinds(Type::cycle);
	obj->cal();
	return 0;
}

工厂模式

简单工厂模式会违反开放封闭原则 在添加类时需要修改子类、枚举类、工厂类、和判断代码

工厂模式通过创立N个工厂类来解决上述问题(对简单工厂模式解耦合),对已经写好的代码无需修改;

#include <bits/stdc++.h>
using namespace std;
// 产品父类 
class shape{
public:
	virtual void cal() = 0;
	virtual ~shape(){
		
	}
}; 

class triangle:public shape{
public:
	void cal() override{
		cout<<"三角形面积"<<endl;
	}
};

class square:public shape{
public:
	void cal() override{
		cout<<"正方形面积"<<endl;
	}
};

class cycle:public shape{
public:
	void cal() override{
		cout<<"圆形面积"<<endl;
	}
};

// 工厂类
class fac{
public:
	virtual shape* creat_kinds() = 0;
	virtual ~fac(){
		
	}
}; 

class triangle_fac:public fac{
public:
	shape* creat_kinds(){
		return new triangle;
	}
	~triangle_fac(){
		cout<<"三角形被析构"; 
	}
};
class square_fac:public fac{
public:
	shape* creat_kinds(){
		return new square;
	}
	~square_fac(){
		cout<<"三角形被析构"; 
	}
};

class cycle_fac:public fac{
public:
	shape* creat_kinds(){
		return new cycle;
	}
	~cycle_fac(){
		cout<<"三角形被析构"; 
	}
};
int main(){
	fac* cur = new cycle_fac;
	shape* obj = cur->creat_kinds();
	obj->cal();
	
	delete obj;
	delete cur;
	
	return 0;
}

抽象工厂模式

通过造船,船分为三个模块,船体、武器、动力,三个模块又分为了简易、标准、旗舰三个版本

#include <bits/stdc++.h>
using namespace std;
// 三个抽象类 每个抽象类下三个具体派生类
// 抽象工厂类 一个抽象类 三个派生类
class body{
public:
	virtual void getbody() = 0;
	virtual ~body(){
		
	}
}; 

class wood_body:public body{
public:
	void getbody() override{
		cout<<"船的船体为<木头>---";
	}
};

class iron_body:public body{
public:
	void getbody() override{
		cout<<"船的船体为<钢铁>---";
	}
};

class mental_body:public body{
public:
	void getbody() override{
		cout<<"船的船体为<合成金属>---";
	}
};

class weapon{
public:
	virtual void getweapon() = 0;
	virtual ~weapon(){
		
	} 
};

class gun_weapon:public weapon{
public:
	void getweapon() override{
		cout<<"船的武器为<枪>---" ;
	}
};

class cannon_weapon:public weapon{
public:
	void getweapon() override{
		cout<<"船的武器为<炮>---" ;
	}
};

class laser_weapon:public weapon{
public:
	void getweapon() override{
		cout<<"船的武器为<激光>---" ;
	}
};


class power{
public:
	virtual void getpower() = 0;
	virtual ~power(){
		
	} 
}; 

class human_power:public power{
public:
	void getpower() override{
		cout<<"船的动力为<手动>---"; 
	}
};

class engine_power:public power{
public:
	void getpower() override{
		cout<<"船的动力为<内燃机>---"; 
	}
};

class nuclear_power:public power{
public:
	void getpower() override{
		cout<<"船的动力为<核反应堆>---"; 
	}
};

class ship{
private:
	body* m_body;
	weapon* m_weapon;
	power* m_power;
public:
	ship(body* o_body , weapon* o_weapon , power* o_power):m_body(o_body) , m_weapon(o_weapon) , m_power(o_power){
		m_body->getbody();
		m_weapon->getweapon();
		m_power->getpower(); 
	}
	~ ship(){
		delete m_body;
		delete m_weapon;
		delete m_power;
	} 
};

class fac{
public:
	virtual ship* get() = 0;
	~ fac(){
		
	}
}; 

class e_fac:public fac{
public:
	ship* get() override{
		ship* cur = new ship(new wood_body , new gun_weapon , new human_power);
		return cur;
	}
};

class m_fac:public fac{
public:
	ship* get() override{
		ship* cur = new ship(new iron_body , new cannon_weapon , new engine_power);
		
		return cur;
	}
};

class h_fac:public fac{
public:
	ship* get() override{
		ship* cur = new ship(new mental_body , new laser_weapon , new nuclear_power);
		return cur;
	}
};

int main() {
	fac* cur = new h_fac;
	ship* res = cur->get();
	delete cur;
	delete res;
	return 0;
}

描述:首先定义三个抽象类,代表船的三个组成部分(船体、武器、动力);每个抽象类下有三个派生类,分别对应初级船、中级船、高级船所用的对应材料。通过ship类将船的三个部分组成起来,一个工厂抽象类fac,通过工厂抽象类的派生类,结合ship类设置三种规格的船。


http://lihuaxi.xjx100.cn/news/1475340.html

相关文章

c++ java rgb与nv21互转

目录 jni函数 c++ rgb转nv21,可以转,不报错,但是转完只有黑白图 java yuv420保存图片,先转nv21,再保存ok: c++ yuv420月bgr互转,测试ok jni函数 JNIEXPORT void JNICALL Java_com_tencent_blazefacencnn_BlazeFaceNcnn_encode(JNIEnv *env,jobject thiz, jobject in…

自定义滑动到底部触发指令,elementUI实现分页下拉框

在 main.js 中添加 // 自定义滑动到底部指令 Vue.directive(selectLoadMore, {bind(el, binding) {// 获取element-ui定义好的scroll盒子const SELECTWRAP_DOM el.querySelector(.el-select-dropdown .el-select-dropdown__wrap)SELECTWRAP_DOM.addEventListener(scroll, fun…

LLM-Rec:基于提示大语言模型的个性化推荐

1. 基本信息 论文题目:LLM-Rec: Personalized Recommendation via Prompting Large Language Models 作者:Hanjia Lyu, Song Jiang, Hanqing Zeng, Yinglong Xia, Jiebo Luo 机构:University of Rochester, University of California Los Angeles, Meta AI, University of Ro…

VBA Excel自定义函数的使用 简单的语法

一个简单的教程&#xff0c;实现VBA自定义函数。 新建模块 复制后面的代码放进来 函数的入口参数不定义&#xff0c;则认为是一块区域&#xff1b; 反之&#xff0c;如FindChar1 As String&#xff0c;则认为是输入的单值。 循环和分支如下例子&#xff0c;VB比较接近自然语…

Nodejs+Typescript+Eslint+Prettier+Husky项目构建

NodejsTypescriptEslintPrettierHusky项目构建 准备工作初始化项目Eslint安装和配置Prettier安装和配置在Eslint中使用Prettier插件Husky安装和配置修改package.json 准备工作 确保已经安装了git以及Node.js和npm&#xff0c;通过git -v、node -v和npm -v检查是否安装。 初始…

SpringCloud学习笔记(四)_ZooKeeper注册中心

基于Spring Cloud实现服务的发布与调用。而在18年7月份&#xff0c;Eureka2.0宣布停更了&#xff0c;将不再进行开发&#xff0c;所以对于公司技术选型来说&#xff0c;可能会换用其他方案做注册中心。本章学习便是使用ZooKeeper作为注册中心。 本章使用的zookeeper版本是 3.6…

STM32 进不了main 函数

1. 我用的是STM32L151C8T6 的芯片&#xff0c;在github 上找了个别人的例程&#xff0c;拿来当模板改&#xff0c;由于他用的是HSE 外部晶振&#xff0c;我用的是内部晶振HSI&#xff0c;所以需要改系统时钟&#xff0c;改完后debug&#xff0c; 一直进不了main 函数&#xff0…

Diffusion Models for Time Series Applications: A Survey

Diffusion Models for Time Series Applications: A Survey (Paper reading) Lequan Lin, The University of Sydney Business School, arXiv2023,Cited:5, Code, Paper 1. 引言 扩散模型是一类基于深度学习的生成模型&#xff0c;在前沿的机器学习研究中变得越来越突出。在…