从0开始写上下文切换

💡 原文中文,约2800字,阅读约需7分钟。
📝

内容提要

栈协程的核心是执行上下文,栈用于存储调用链和变量,切换栈即切换上下文。boost.fcontext将栈视为协程的核心,简化了上下文切换的代码。创建新协程需要三个参数,涉及栈和用户函数。跨平台实现需针对不同CPU和调用约定重写代码。

🎯

关键要点

  • 栈协程的核心是执行上下文,栈用于存储调用链和变量。

  • 切换栈等于切换上下文,栈在协程切换中占据核心地位。

  • boost.fcontext将栈视为协程的核心,简化了上下文切换的代码。

  • 创建新协程需要三个参数:栈、用户函数和函数参数。

  • 上下文切换的过程是将当前状态入栈,切换栈顶,然后出栈。

  • ucontext和boost.fcontext在上下文的理解上存在设计差异。

  • 栈的设计简化了上下文切换的代码,影响了make_context的设计。

  • 新建协程的出生点代码不需要暴露给用户,其他两个函数作为库接口存在。

  • 跨平台实现需要针对不同CPU和调用约定重写代码,工作量较大。

➡️

继续阅读