免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: Unix_C_Linux
打印 上一主题 下一主题

[C] 请教关于线程的问题 [复制链接]

论坛徽章:
1
2015亚冠之阿尔艾因
日期:2015-08-24 15:46:57
11 [报告]
发表于 2015-08-24 15:48 |只看该作者
这是生产者消费者不。。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
12 [报告]
发表于 2015-08-25 15:36 |只看该作者
本帖最后由 yulihua49 于 2015-08-27 13:48 编辑
Unix_C_Linux 发表于 2015-08-21 10:01
大家好,有主进程A接收数据,现在想异步的对这些数据进行操作,然后临时存储,开了一个线程对他操作。我想问 ...

这就是我的处理线程,消费者。可以有很多线程在干:

  1. static void * cli_sched(void *reg)
  2. {
  3. tpool_node *thp=(tpool_node *)reg;
  4. int ret;
  5. struct epoll_event event;
  6. dlq_node *dlp;

  7.         pthread_detach(thp->tid);
  8.         thp->flg=0;
  9.         ShowLog(2,"%s:tid=%lX created",__FUNCTION__,thp->tid);
  10.         while(1) {
  11.           if(lnum<LNUM) { //有几个线程在等epoll
  12.                 lnum++;
  13.                 ret = epoll_wait(epfd, &event, 1,-1);//等待服务器返回的消息
  14.                 lnum--;
  15.                 if(ret<0) break; //epfd关闭了,退出
  16.                 dlp=(dlq_node *)event.data.ptr;
  17.                 to_epoll(dlp,EPOLL_CTL_DEL,0);
  18.           } else { //其他线程在等队列
  19.                 pthread_mutex_lock(&tmutx);
  20.                 while(NULL==(dlp=dlq_get(&tqueue))) { //提交给本线程池处理的消息
  21.     //这就是告诉你的,等消息。其他线程加入队列后:pthread_cond_signal(&tcond);
  22.                        pthread_cond_wait(&tcond,&tmutx);
  23.                  }
  24.                 pthread_mutex_unlock(&tmutx);
  25.           }
  26.           if(dlp->callback) ret=dlp->callback(dlp);
  27.         }
  28.         thp->flg=-1;
  29.         return NULL;
  30. }

复制代码

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
13 [报告]
发表于 2015-08-27 16:05 |只看该作者
本帖最后由 yulihua49 于 2015-08-27 16:19 编辑
Unix_C_Linux 发表于 2015-08-21 10:01
大家好,有主进程A接收数据,现在想异步的对这些数据进行操作,然后临时存储,开了一个线程对他操作。我想问 ...

二者都是可以多线程的。等待过程不消耗CPU.

  1. //消费者
  2. dlq_node *Q_get()
  3. {
  4. dlq_node *dlp;
  5.         pthraed_mutex_lock(&Q_free.mut);
  6.         while(NULL==(dlp=dlq_get(&Q_free.queue))) {
  7.                 pthread_cond_wait(&Q_free.cond,&Q_free.mut);//等生产者通知
  8.         }
  9.         pthraed_mutex_unlock(&Q_free.mut);
  10.         return dlp;
  11. }

  12. //生产者
  13. int Q_release(dlq_node *dlp)
  14. {
  15. int ret;
  16.         if(!dlp) return -1;
  17.         pthraed_mutex_lock(&Q_free.mut);
  18.         ret=dlq_add(&Q_free.queue,dlp);
  19.         pthraed_mutex_unlock(&Q_free.mut);
  20.         phread_cond_signal(&Q_free.cond);//通知消费者
  21.         return ret;
  22. }
复制代码
其实挺简单的,就是把你原来想sleep的地方换成pthread_cond_wait就行了。

  1. while(NULL==(dlp=dlq_get(&Q_free.queue))) {
  2.           usleep(1000);
  3. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP