【12】c++设计模式——>单例模式练习(任务队列)

属性:

(1)存储任务的容器,这个容器可以选择使用STL中的队列(queue)

(2)互斥锁,多线程访问的时候用于保护任务队列中的数据

方法:主要是对任务队列中的任务进行操作

(1)任务队列中任务是否为空

(2)往任务队列中添加一个任务

(3)从任务队列中取出一个任务

(4)从任务队列中删除一个任务

根据分析,就可以把这个饿汉模式的任务队列的单例类定义出来了:

cpp 复制代码
#include <iostream>
#include <mutex>
#include <thread>
#include <queue>
using namespace std;

//创建一个饿汉模式单例
class TaskQueue
{
public:
	static TaskQueue* getInstance()
	{
		cout << "我是一个饿汉单例模式" << endl;
		return m_obj;
	}
	//任务队列是否为空
	bool isEmpty()
	{
		lock_guard<mutex> locker(m_mutex);
		return m_taskQ.empty();
	}
	//添加任务
	void pushTask(int task)
	{
		lock_guard<mutex> locker(m_mutex);
		m_taskQ.push(task);
	}
	//删除任务
	bool popTask()
	{
		lock_guard<mutex> locker(m_mutex);
		if (!m_taskQ.empty())
		{
			m_taskQ.pop();
			return true;
		}
		return false;
	}
	//取出来一个任务
	int getTask()
	{
		lock_guard<mutex> locker(m_mutex);
		if (!m_taskQ.empty())
		{
			return m_taskQ.front();
		}
		return -1;
	}
	
private:
	TaskQueue() = default; //无参构造
	static TaskQueue* m_obj; //单例
	queue<int> m_taskQ; //任务队列
	mutex m_mutex; //互斥锁
};
TaskQueue* TaskQueue::m_obj = new TaskQueue;

int main()
{
	
	//创建线程1(生产者)
	thread t1([]() {
		TaskQueue* obj = TaskQueue::getInstance();
		for (int i = 0; i < 10; i++)
		{
			obj->pushTask(i+100);
			cout << "taskID:" << i + 100 << ",threadID:" << this_thread::get_id() << endl;
			this_thread::sleep_for(chrono::microseconds(500));
		}
	});

	//创建线程2(消费者)
	thread t2([]() {
		TaskQueue* obj = TaskQueue::getInstance();
		this_thread::sleep_for(chrono::microseconds(100));
		while (!obj->isEmpty())
		{
			cout << "taskID:" <<obj->getTask()<< ",threadID:" << this_thread::get_id() << endl;
			obj->popTask();
			this_thread::sleep_for(chrono::microseconds(500));
		}
	});
	t1.join();
	t2.join();
}
相关推荐
踏莎行hyx19 分钟前
使用langchain连接llama.cpp部署的本地deepseek大模型开发简单的LLM应用
c++·ai·langchain·大模型·llama.cpp·deepseek
山河木马27 分钟前
前端学C++可太简单了:双冒号 :: 操作符
前端·javascript·c++
鸡蛋灌Bean28 分钟前
Java常用设计模式大全
java·开发语言·设计模式
喝可乐的布偶猫29 分钟前
Java-----韩顺平单例设计模式学习笔记
java·笔记·设计模式
WISHMELUCK1'31 分钟前
设计模式的六大设计原则
设计模式·接口隔离原则·依赖倒置原则·里氏替换原则·迪米特法则·合成复用原则·单一职责原则
乌萨奇也要立志学C++1 小时前
【C++详解】STL-list模拟实现(深度剖析list迭代器,类模板未实例化取嵌套类型问题)
c++·list
闻缺陷则喜何志丹2 小时前
【前缀和 BFS 并集查找】P3127 [USACO15OPEN] Trapped in the Haybales G|省选-
数据结构·c++·前缀和·宽度优先·洛谷·并集查找
序属秋秋秋3 小时前
《C++初阶之内存管理》【内存分布 + operator new/delete + 定位new】
开发语言·c++·笔记·学习
Hellyc8 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
追烽少年x8 小时前
设计模式---观察者模式(发布-订阅模式)
网络·设计模式