协程设计原理(理论)

为什么有协程,协程用来干什么?

协程有着同步的编程方式,异步的性能。即写代码是同步的方式写的,运行起来是异步的
异步:检测io(调度器)与io操作不在一个流程中。如检测io(epoll_wait()判断fd读写状态)与io操作(send(),recv())
同步:检测io与io操作在一个流程中

//以网络io为例 同步的写法(单线程)有着多线程的性能
while(1)
{
	epoll_wait()
	for(;;)// 处理对应的fd
	{
		recv();
		// 处理数据();
		send();
	}
}

原语操作

1、yield(让出)
io操作的操作->检测io的操作
2、resume(恢复)
检测io的操作->io操作的操作

大致思路

// 以下为伪代码,主要是理解协程的流程
void func()
{
	while(1)
	{
		int fd; // 多个客户端
		send(fd,buf,bufsize);
		epoll_ctl(epfd,...);// 添加EPOLLOUT fd进去
		yield;// 将控制权让出给调度器
		recv()
		epoll_ctl();
		yield;
	}
}
// 调度器
{
	int nready = epoll_wait(epfd,..);
	for(int i=0; i<nready; i++)
	{
		........
	}
	ret;//resume 恢复主流程
}

在这里插入图片描述

实现方法

1、用setjmp/longjmp,标准c提供的接口 //不推荐,可读性比较差
2、用ucontext,linux系统提供的接口
3、用汇编的代码自己实现

协程适用场景

适用于io密集型,如高并发的服务器,要求及时性,使用协程是个比较好的方法。
不适用于io不密集的场景,因为针对单个io操作,不需要不断地让出和恢复来切换io,因此在检测io时不断地让出和恢复只会适得其反

技术参考

视频技术参考:https://ke.qq.com/course/417774?flowToken=1041651

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值