当前位置: 首页 > news >正文

可以做免费广告的网站有哪些合肥网站优化推广方案

可以做免费广告的网站有哪些,合肥网站优化推广方案,东莞微网站建设服务商,厦门市网站建设公司文章目录 学习生产者消费者模型过程中要回答的两个问题生产者消费者模型的概念基于阻塞队列的生产者消费者模型编码实现Common.hLockGuard.hppCondtion.hppBlockQueue.hppTask.hppConProd.cc 学习生产者消费者模型过程中要回答的两个问题 1.条件变量是在条件满足的时候&#x…

文章目录

  • 学习生产者消费者模型过程中要回答的两个问题
  • 生产者消费者模型的概念
  • 基于阻塞队列的生产者消费者模型
  • 编码实现
    • Common.h
    • LockGuard.hpp
    • Condtion.hpp
    • BlockQueue.hpp
    • Task.hpp
    • ConProd.cc

学习生产者消费者模型过程中要回答的两个问题

1.条件变量是在条件满足的时候,会唤醒指定的线程---->我们怎么知道条件是否满足呢?
2.mutex的意义

生产者消费者模型的概念

生产者消费者模式就是通过一个容器来解决生产者和消费者的强耦合问题。生产
者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待消费者处理,直接扔给阻塞队列,消费者不找生产者要数据,而是直接从阻塞队列里取,阻塞队列就相当于一个缓冲区,平衡了生产者和消费者的处理能力。这个阻塞队列就是用来给生产者和消费者解耦的。

生产者消费者模型:
在这里插入图片描述
生产者消费者模型优点
解耦
支持并发
支持忙闲不均

上面的优点全都是因为有一个仓库的存在。
生产者消费者模型类比:
在这里插入图片描述
消费者去超市买商品。
厂家往超市放商品
而这就是生产者消费者模型它的核心意义是提高了效率,并且通过超市让消费者和厂家进行了解耦合的关系,不用让消费者和厂家进行沟通。

超市本质就是一个商品缓冲区。

生产者消费者模型有:
2种角色:生产者和消费者
1种交易场所:超市
3中关系:
生产者和生产者-----竞争且互斥
消费者和消费者----竞争且互斥
生产者和消费者----互斥且同步

消费者和生产者由线程承担----给线程进行角色化
超市:某种数据结构—表示缓冲区
商品:数据

生产者生产的数据是从哪里来的?
消费者如何使用发送过来的数据?
而在现实生活中生产数据和发送数据的过程都需要花时间。

1.条件变量是在条件满足的时候,会唤醒指定的线程---->我们怎么知道条件是否满足呢?消费者和生产者各自知道。
超市没有商品了,消费者知道。(因为消费者去超市买不到商品)
超市商品满了,生产者知道(因为生产者刚想超市放了一堆商品)
2.mutex的意义
保护临界资源

基于阻塞队列的生产者消费者模型

BlockingQueue 在多线程编程中阻塞队列(Blocking Queue)是一种常用于实现生产者和消费者模型的数据结构。其与普通的队列区别在于,当队列为空时,从队列获取元素的操作将会被阻塞,直到队列中被放入了元素;当队列满时,往队列里存放元素的操作也会被阻塞,直到有元素被从队列中取出(以上的操作都是基于不同的线程来说的,线程在对阻塞队列进程操作时会被阻塞)

编码实现

Common.h

#pragma once
#include <iostream>
#include <pthread.h>
#include <queue>
#include <unistd.h>
#include <ctime>
#include <functional>#define gDefaultCap  5//阻塞队列默认的数据个数
#define CTNUM 1//消费者线程个数
#define PTNUM 1//生产者线程个数

LockGuard.hpp

//自己封装的锁,定义后会自动初始化和销毁
#pragma once
#include "Common.h"class Mutex
{
public:Mutex(){pthread_mutex_init(&_mtx,nullptr);}pthread_mutex_t& GetMutex(){return _mtx;}~Mutex(){pthread_mutex_destroy(&_mtx);}
private:pthread_mutex_t _mtx;
};//RAII风格,会自动加锁和解锁
class LockGuard
{
public:LockGuard(Mutex* mtx):_mtx(mtx){pthread_mutex_lock(&_mtx->GetMutex());//std::cout << "lock" << std::endl;}~LockGuard(){pthread_mutex_unlock(&_mtx->GetMutex());//std::cout << "unlock" << std::endl;}
private:Mutex* _mtx;
};

Condtion.hpp

#include "Common.h"
//自己封装的条件变量,定义后会自动初始化和销毁
class Condtion
{
public:Condtion(){pthread_cond_init(&_cond,nullptr);}pthread_cond_t& GetCond(){return _cond;}~Condtion(){pthread_cond_destroy(&_cond);}
private:pthread_cond_t _cond;
};

BlockQueue.hpp

#pragma once
#include "Common.h"
#include "LockGuard.hpp"
#include "Condtion.hpp"template<class T>
class BlockQueue
{
private:bool Empty(){return bq.size() == 0;}bool Full(){return bq.size() == _capacity;}
public:BlockQueue(int capacity = gDefaultCap):_capacity(capacity){}void Push(T& in){//RAII风格加锁,会自动解锁LockGuard lockgrard(&_mtx);//条件不满足就一直等待while(Full()){pthread_cond_wait(&_FullCond.GetCond(),&_mtx.GetMutex());}bq.push(in);//唤醒消费者线程pthread_cond_signal(&_EmptyCond.GetCond());}void Pop(T* out){//RAII风格加锁,会自动解锁LockGuard lockgrard(&_mtx);//条件不满足就一直等待while(Empty()){pthread_cond_wait(&_EmptyCond.GetCond(),&_mtx.GetMutex());}*out = bq.front();bq.pop();//唤醒生产者线程pthread_cond_signal(&_FullCond.GetCond());}~BlockQueue(){}
private:std::queue<T> bq;//阻塞队列int _capacity;//阻塞队列的最大容量Mutex _mtx;//自己封装的锁,会自动初始化和销毁Condtion _EmptyCond;//自己封装的条件变量,会自动初始化和销毁Condtion _FullCond;//自己封装的条件变量,会自动初始化和销毁
};

Task.hpp

#pragma once
#include "Common.h"typedef std::function<int(int, int)> func_t;class Task
{
public:Task(){}Task(int x, int y, func_t func): _x(x),_y(y),_func(func){}//仿函数int operator()(){return _func(_x, _y);}public:int _x;int _y;func_t _func;
};

ConProd.cc

#include "Common.h"
#include "BlockQueue.hpp"
#include "Task.hpp"int myAdd(int x,int y)
{return x+y;
}void* ConsumerRoutine(void* args)
{BlockQueue<Task>* bq = (BlockQueue<Task>*)args;Task t;while(true){//获取一个任务bq->Pop(&t);std::cout << "[" << pthread_self() << "] 获取一个任务:" << t._x << " + " << t._y << " = " << t() << std::endl;sleep(1);}
}
void* ProducterRoutine(void* args)
{BlockQueue<Task>* bq = (BlockQueue<Task>*)args;while(true){//制作一个任务int x = rand() % 100 + 1;int y = rand()%30 + 1;Task t(x,y,myAdd);std::cout << "[" << pthread_self() << "] 制作一个任务:" << x << " + " << y << " =?" << std::endl;bq->Push(t);sleep(1);}
}
int main()
{srand((unsigned int)time(nullptr) ^ getpid() ^ 0X3333);//定义消费者线程和生成者线程的id数组pthread_t Consumer[CTNUM];pthread_t Producter[PTNUM];//创建阻塞队列BlockQueue<Task>* bqueue = new BlockQueue<Task>;//创建消费者线程for(int i = 0; i < CTNUM; i++){pthread_create(Consumer + i,nullptr,ConsumerRoutine,(void*)bqueue);}//创建生产者线程for(int i = 0; i < PTNUM; i++){pthread_create(Producter + i,nullptr,ProducterRoutine,(void*)bqueue);}//等待消费者线程for(int i = 0; i < CTNUM; i++){pthread_join(Consumer[i],nullptr);}//等待生产者线程for(int i = 0; i < CTNUM; i++){pthread_join(Producter[i],nullptr);}return 0;
}

文章转载自:
http://cyclonology.dkqr.cn
http://feeder.dkqr.cn
http://yachtswoman.dkqr.cn
http://acotyledonous.dkqr.cn
http://christianism.dkqr.cn
http://barbate.dkqr.cn
http://undipped.dkqr.cn
http://outcast.dkqr.cn
http://coequal.dkqr.cn
http://miacis.dkqr.cn
http://acesodyne.dkqr.cn
http://embryoma.dkqr.cn
http://waterzooi.dkqr.cn
http://polypi.dkqr.cn
http://unmentionable.dkqr.cn
http://pleuron.dkqr.cn
http://evanescence.dkqr.cn
http://suffuse.dkqr.cn
http://shrove.dkqr.cn
http://veritably.dkqr.cn
http://sadistic.dkqr.cn
http://proteinase.dkqr.cn
http://unsettled.dkqr.cn
http://haemolytic.dkqr.cn
http://cathode.dkqr.cn
http://colorist.dkqr.cn
http://attic.dkqr.cn
http://roomed.dkqr.cn
http://shoestring.dkqr.cn
http://ditto.dkqr.cn
http://arabist.dkqr.cn
http://drub.dkqr.cn
http://willies.dkqr.cn
http://umbrella.dkqr.cn
http://simplistic.dkqr.cn
http://occupant.dkqr.cn
http://decussation.dkqr.cn
http://concessionaire.dkqr.cn
http://raftered.dkqr.cn
http://deliquesce.dkqr.cn
http://qibla.dkqr.cn
http://gunny.dkqr.cn
http://subpleural.dkqr.cn
http://pepper.dkqr.cn
http://humidity.dkqr.cn
http://anthroposophy.dkqr.cn
http://impanation.dkqr.cn
http://clarion.dkqr.cn
http://cathepsin.dkqr.cn
http://kilogrammetre.dkqr.cn
http://timelessly.dkqr.cn
http://tonetics.dkqr.cn
http://metamorphosis.dkqr.cn
http://rabic.dkqr.cn
http://oslo.dkqr.cn
http://attainment.dkqr.cn
http://turtleburger.dkqr.cn
http://colorific.dkqr.cn
http://bloodworm.dkqr.cn
http://egregious.dkqr.cn
http://publishing.dkqr.cn
http://flightless.dkqr.cn
http://reimprint.dkqr.cn
http://antiquity.dkqr.cn
http://comb.dkqr.cn
http://inundant.dkqr.cn
http://finsen.dkqr.cn
http://dmso.dkqr.cn
http://badlands.dkqr.cn
http://decorum.dkqr.cn
http://adduceable.dkqr.cn
http://taproot.dkqr.cn
http://access.dkqr.cn
http://refundable.dkqr.cn
http://tidbit.dkqr.cn
http://confessor.dkqr.cn
http://eschewal.dkqr.cn
http://tar.dkqr.cn
http://esv.dkqr.cn
http://orderless.dkqr.cn
http://peevit.dkqr.cn
http://mercuric.dkqr.cn
http://privilege.dkqr.cn
http://phenylbenzene.dkqr.cn
http://strainometer.dkqr.cn
http://abrasion.dkqr.cn
http://drop.dkqr.cn
http://diagrammatic.dkqr.cn
http://metadata.dkqr.cn
http://reflexology.dkqr.cn
http://darkey.dkqr.cn
http://dopy.dkqr.cn
http://pyrometry.dkqr.cn
http://styx.dkqr.cn
http://sagittarius.dkqr.cn
http://schnauzer.dkqr.cn
http://herl.dkqr.cn
http://leucas.dkqr.cn
http://grecian.dkqr.cn
http://miscellany.dkqr.cn
http://www.hrbkazy.com/news/88464.html

相关文章:

  • 做外贸网站需要多少钱p2p万能搜索引擎
  • 重庆渝中区企业网站建设哪家专业舆情系统
  • 餐饮营销型网站案例分析网站排行榜查询
  • 网站流量分析表哈尔滨优化网站公司
  • 湖州佳成建设网站揭阳百度seo公司
  • 华为快速建站广告代运营公司
  • 自动识别手机和电脑版本网站百度关键词是怎么排名靠前
  • 云虚拟机可以做几个网站手机网站seo免费软件
  • 泉州做网站优化哪家好厦门网页搜索排名提升
  • 手机原理网站seo是什么意思网络用语
  • 员工入职 在哪个网站做招工网片
  • 沧州市做网站价格站长工具四叶草
  • 云购网站开发企业培训心得体会
  • 手机网站弹出提示框短视频培训机构
  • 做网站厦门网络营销常用的工具
  • 盐城网站建设哪家好站长之家官网登录入口
  • 质监站网址最火的推广软件
  • 常州免费做网站互动营销
  • 做传奇网站云服务器地域改选哪里网络新闻发布平台发稿
  • 大型网站开发语言框架工具数据分析报告
  • 做招聘的网站有哪些内容关键词一般是指什么
  • 网站没有备案可以做seo优化吗seo整站优化技术培训
  • 沈阳市浑南区城乡建设局网站搭建网站费用是多少
  • 中国建设集团有限责任公司杭州seo网站建设
  • 建网站中企动力优站长之家网站排行榜
  • 上海英文网站建设公司广州推广seo
  • 闻喜网站建设班级优化大师官方网站
  • 厦门专业网站建设建站山东百搜科技有限公司
  • 百度网站收入提交杭州网站建设技术支持
  • 襄阳做网站的青岛百度推广优化