共享内存,共享缓冲区 一对多

来源:互联网 发布:linux 下载整个文件夹 编辑:程序博客网 时间:2024/06/06 03:23

produce:

for(int i=0;i<m_push_thread;i++){

if(iter == VecS2SResult.end()){
break;
}
if(g_Empty_sem_obj[i].sem_trywait()==0){
//获取到信号量

g_push_consume_cache[i].msgid = (*iter)["FmsgId"];
g_push_consume_cache[i].appid = (*iter)["Fappid"];

iter = VecS2SResult.erase(iter);
g_Full_sem_obj[i].sem_post();
}

}

consume:

while(1){
//等待信号量
g_Full_sem_obj[threadId].sem_wait();
do_something();
g_Empty_sem_obj[threadId].sem_post();
}

0 0