我是靠谱客的博主 醉熏小蜜蜂,最近开发中收集的这篇文章主要介绍一个C/C++协程库的思考与实现之协程的errno与信号处理,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

https://github.com/DoasIsay/ToyCoroutine

每个线程都有自己的errno,那么协程是否也需要自已的errno?

如果这样写代码,那每个协程要有自已的errno

在hook的系统调用中当io读写不能满足时,就进行协程切换,在io可读写返回到用户代码后继续使用errno,此时的errno可能已经不是协程切换前的errno了,因为期间其它协程也会call系统调用,所以因在hook系统调用的代码中,在协程切换前先保存errno的值,因为协程恢复后会先判断errno,根据errno的值选择是继续读写还是出错返回

但如果在hook的系统调用中一直读写,只有读写到数据或出错才返回,那么协程就不需要自己的errno了,这样写代码,虽然用户用的是非阻塞的系统调用,但在hook的代码中我们还是把它实现成阻塞的,这个阻塞是对协程而言的,一个线程被IO阻塞就会被os调度切换,同样的一个协程被IO阻塞,也会被协程的调度器调度切换,我们要把被hook的阻塞的系统调用仍实现为对协程而言是阻塞的,让用户无法感知到他使用的是非阻塞的接口,让用户可以写同步的代码

但是这样就无法在协程库中检测到协程的退出条件,而提前返回,因此要想办法把协程的退出从用户代码传递到协程库的代码中,也就是hook的系统调用中,请不要使用全局变量isExit这种简单粗爆的方法,我们要尽量实现的优雅一些,这时我终于找到了让协程支持信号处理的理由

实现了协程库后,我第一个为协程实现的feature就是信号处理,为协程实现信号处理的第一个原因就是,当时的协程并不能优雅的退出,我想依靠发送信号来通知协程退出,后来我找到了另一种解决协程退出的问题方法

但现在我觉得把hook的系统调用仍实现为对协程而言是阻塞的是一种不错的想法,但是又不能在协程库中使用用户代码中的isExit变量来检测退出,那只能用信号了,当协程收到信号无论IO是否满足还是在等待一个超时,都会返回被信号中断的错误,在hook的系统调用中检测到错误后以出错返回,于是我们去除了协程的errno也用上了协程的信号处理机制

新的问题又出现了,如果协程关联的fd没有IO事件,协程是不会被调度的,因此协程还是无法返回,仍然是被IO阻塞着,对于这样简单的问题同样要用简单的方法解决,把收到信号的协程放入到runQueue

最后

以上就是醉熏小蜜蜂为你收集整理的一个C/C++协程库的思考与实现之协程的errno与信号处理的全部内容,希望文章能够帮你解决一个C/C++协程库的思考与实现之协程的errno与信号处理所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部