先贴一下libco的生产者消费例子(来源于腾讯开源项目libco)
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <queue>
#include "co_routine.h"
using namespace std;
struct stTask_t
{
int id;
};
struct stEnv_t
{
stCoCond_t* cond;
queue<stTask_t*> task_queue;
};
void* Producer(void* args)
{
co_enable_hook_sys();
stEnv_t* env= (stEnv_t*)args;
int id = 0;
while (true)
{
stTask_t* task = (stTask_t*)calloc(1, sizeof(stTask_t));
task->id = id++;
env->task_queue.push(task);
printf("%s:%d produce task %d\n", __func__, __LINE__, task->id);
co_cond_signal(env->cond); //通知消费者继续工作
poll(NULL, 0, 1000);//挂起
}
return NULL;
}
void* Consumer(void* args)
{
co_enable_hook_sys();
stEnv_t* env = (stEnv_t*)args;
while (true)
{
if (env->task_queue.empty())
{
co_cond_timedwait(env->cond, -1); //放弃cpu,转让给生产者协程
continue;
}
stTask_t* task = env->task_queue.front();
env->task_queue.pop();
printf("%s:%d consume task %d\n", __func__, __LINE__, task->id);
free(task);
}
return NULL;
}
int main()
{
stEnv_t* env = new stEnv_t;
env->cond = co_cond_alloc();
stCoRoutine_t* consumer_routine;
co_create(&consumer_routine, NULL, Consumer, env); //创建消费者
co_resume(consumer_routine);//提交消费协程
stCoRoutine_t* producer_routine;
co_create(&producer_routine, NULL, Producer, env); //创建生产者
co_resume(producer_routine);//提交生产者协程
co_eventloop(co_get_epoll_ct(), NULL, NULL);协程事件循环
return 0;
}
libco是一个非对称协程,具有父子关系;
协程就是在一个线程中来回切换工作。