一种简单高效的生产者消费者多线程实现

一种简单高效的生产者消费者多线程实现

初衷

解决几个问题:

  • 主线程阻塞时间太长。
  • 工作线程阻塞时间太长。
  • 过多的同步代码导致结构复杂。
  • 不能动态的调整工作线程数量。

实现方式

  • 主线程有一个任务队列A,每个工作线程也有一个任务队列B。
  • 主线程中收到一个请求时,在队列A中添加任务。
  • 主线程在循环中:
    • 如果工作线程没有锁定队列B,那么主线程从队列A中取任务,放到队列B中,并唤醒工作线程。检查是否锁定使用TryEnterCriticalSection(Windows)/pthread_mutex_trylock(Linux)。
    • 如果工作线程锁定了队列B,那么主线程跳过,避免主线程阻塞。
    • 如果有已经完成的任务,则回调给请求者。任务完成通过状态变量检查,避免阻塞。
    • 可以动态的添加、删除工作线程,删除时只要判断工作线程没有锁定自己的任务队列B即可。
  • 工作线程:
    • 处理整个队列B的任务。
    • 完成的任务设置状态变量为完成,注意使用Interlocked函数(Windows)/__sync_add_and_fetch(Linux),避免工作线程阻塞。
    • 然后睡眠,等待主线程唤醒。

这种实现有几个特点:

  • 任务队列A不需要锁。
  • 任务队列B需要锁,但不会阻塞主线程。
  • 使用状态变量,简化线程同步操作,减少任务回调等待时间。
  • 依赖于主线程的循环操作。

转载于:https://www.cnblogs.com/tinyfish/archive/2013/01/10/2855026.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值