setjmp/longjmp实现轻量级协程切换
利用非局部跳转实现协作式多任务,保存和恢复栈环境,模拟简单协程调度,揭示栈帧指针操作。 · 难度:入门 · +10XP
setjmp/longjmp协程
setjmp保存当前栈环境到jmp_buf,longjmp恢复。本教程用这两个函数实现两个“任务”轮流执行:每次任务调用yield()时保存自身状态并跳回调度器。重点讲解jmp_buf存储的寄存器(sp、bp等)以及为何不能跨越函数调用(栈帧失效)。实现一个极简调度循环。
#include <stdio.h>
#include <setjmp.h>
jmp_buf main_buf, task1_buf, task2_buf;
void task1() {
printf("task1 start
");
if (setjmp(task1_buf) == 0) longjmp(main_buf, 1);
printf("task1 resume
");
longjmp(main_buf, 1);
}
void task2() {
printf("task2 start
");
if (setjmp(task2_buf) == 0) longjmp(main_buf, 1);
printf("task2 resume
");
longjmp(main_buf, 1);
}
int main() {
if (setjmp(main_buf) == 0) {
task1();
} else {
task2();
}
return 0;
}