libco协程学习

本文介绍了腾讯开源项目libco的一个生产者-消费者实例,详细展示了如何使用libco创建和管理协程。通过co_enable_hook_sys()、co_cond_signal()和co_cond_timedwait()等函数实现协程间的通信和同步,阐述了非对称协程的父子关系以及其在线程中的工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先贴一下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是一个非对称协程,具有父子关系;

协程就是在一个线程中来回切换工作。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值