最近做项目,需要调用的一些服务,但是这个服务本身和主线程没有什么关联,所以这时候我们可以将其异步化,从而提升整体的性能。
然后我是怎么做的呢?
第一步,肯定是要开启线程,初始化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)
子线程就锁住缓冲区进行操作了。
其实这个设计的主要思路是,父线程驱动子线程。可以多考虑考虑,这种情况不会死锁。