从0开始写上下文切换
💡
原文中文,约2800字,阅读约需7分钟。
📝
内容提要
栈协程的核心是执行上下文,栈用于存储调用链和变量,切换栈即切换上下文。boost.fcontext将栈视为协程的核心,简化了上下文切换的代码。创建新协程需要三个参数,涉及栈和用户函数。跨平台实现需针对不同CPU和调用约定重写代码。
🎯
关键要点
-
栈协程的核心是执行上下文,栈用于存储调用链和变量。
-
切换栈等于切换上下文,栈在协程切换中占据核心地位。
-
boost.fcontext将栈视为协程的核心,简化了上下文切换的代码。
-
创建新协程需要三个参数:栈、用户函数和函数参数。
-
上下文切换的过程是将当前状态入栈,切换栈顶,然后出栈。
-
ucontext和boost.fcontext在上下文的理解上存在设计差异。
-
栈的设计简化了上下文切换的代码,影响了make_context的设计。
-
新建协程的出生点代码不需要暴露给用户,其他两个函数作为库接口存在。
-
跨平台实现需要针对不同CPU和调用约定重写代码,工作量较大。
🏷️
标签
➡️