libco example_cond.cpp分析

这篇博客分析了腾讯libco库中的example_cond.cpp,简化的程序关注点在于co_eventloop函数。通过深入理解该函数,可以更好地掌握libco库的使用。
摘要由CSDN通过智能技术生成

腾讯libco库的example分析

可以参考https://github.com/zhoudayang/libco

example_cond.cpp

/*
生产者消费者模型
 */
#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 - 设置当前线程中正在运行的协程中使用hook系统调用*/
	co_enable_hook_sys();//函数是用来打开 libco 的钩子标示,进行系统 io 函数的时候才会调用到 libco 的函数而不是原系统函数
	stEnv_t* env=  (stEnv_t*)args;//参数转换,参数里面含有协程条件量cond
	int id = 0;
	while (true)
	{
		stTask_t* task = (stTask_t*)calloc(1, sizeof(stTask_t));//堆内存上分配一个int长度的空间
		task->id = id++;
		env->task_queue.push(task);//任务加到队列尾部
		printf("%s:%d produce task %d\n", __func__, __LINE__, task->id);
		co_cond_signal(env->cond);//设置cond状态,取消这句试试看,这句保证一旦有一个生产,马上就去消费
		poll(NULL, 0, 1000);//将当前协程指针挂到等待队列,pool阻塞时间1000ms,每隔1000ms挂一次。把它设置成0,程序就会一直producer。这句话实现了协程切换。
	}
	return NULL;
}
void* Consumer(void* args)
{
	co_enable_hook_sys();
	stEnv_t* env = (stEnv_t*)args;
	/*死循环使得把任务队列全部执行完毕 */
	while (true)
	{
		if (env->task_queue.empty())
		{
	
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值