异步化方案

12 篇文章 0 订阅
7 篇文章 0 订阅

最近做项目,需要调用的一些服务,但是这个服务本身和主线程没有什么关联,所以这时候我们可以将其异步化,从而提升整体的性能。
然后我是怎么做的呢?
第一步,肯定是要开启线程,初始化mutex

pthread_mutex_t locker;  
pthread_cond_t cond;
pthread_t thread;
queue<AsynJob *> m_qtransfer; //队列作为缓冲区
pthread_mutex_init(&locker, NULL);//初始化锁
pthread_cond_init(&cond, NULL);//初始化条件,它的作用后续会讲到
ret = pthread_create(&thread, NULL, ProcessCycle, reinterpret_cast<void *>(i));//创建线程

我们在生产的时候,怎么做呢?

pthread_mutex_lock(&locker[job_kind]);
m_qtransfer.push(job);  
pthread_cond_signal(&cond[job_kind]);
pthread_mutex_unlock(&locker[job_kind]);

我们在消费的时候怎么做呢?

pthread_mutex_lock(&transfer->locker);
while(!transfer->thread_exit) {
    if (transfer->m_qtransfer.empty())
        {
            pthread_cond_wait(&transfer->cond, &transfer->locker);
            continue;
        }
    ...取出对队列里的任务
    pthread_mutex_unlock(&transfer->locker);
    ...执行任务
    pthread_mutex_lock(&transfer->locker);  
}

整个操作的核心在于pthread_cond_wait和pthread_cond_signal那句:
子线程上来的时候,先锁住缓冲区,如果缓冲区为空,就执行pthread_cond_wait,
这条语句相当于下面两句话形成原子操作

unlock(locker)
sleep();

然后pthread_cond_signal执行之后唤醒子线程进行操作了等于

wake 子线程
lock(locker)

子线程就锁住缓冲区进行操作了。

其实这个设计的主要思路是,父线程驱动子线程。可以多考虑考虑,这种情况不会死锁。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值