需要在函数内部进行跳转可以使用goto,在函数之间进行跳转就需要使用setjmp函数
#include <setjmp.h>
int setjmp(jmp_buf envbuf);
该函数将系统栈保存于envbuf中,以供以后调用longjmp()。当第一次调用setjmp(),它的返回值为0。之后调用longjmp(),longjmp()第二个参数即为setjmp()的返回值。
#include <stdio.h>
#include <stdlib.h>
#include <setjmp.h>
jmp_buf envbuf;
void b()
{
printf("I am b func\n");
longjmp(envbuf,5);//回到 setjmp 位置
}
void a()
{
printf("before b(),I am a func\n");
b();
printf("after b(),I am a func\n");
}
void main()
{
int i;
i=setjmp(envbuf);//保存进程执行的上下文
if(i==0)
{
a();
}
system("pause");
return;
}
“after b(),I am a func\n”);这一句没有得到打印,因为 b 中的 longjmp 直接跳转到 setjmp 的位置,这时 i 的值为 5,从而实现了从 b 函数直接跳转到 main 函数的操作。
当进程执行到 setjmp 位置时,通过 setjmp 函数保存了进程的上下文(处理器运行进程期间,运行进程的信息被存储在处理器的寄存器和高速缓存中,执行的进程被加载到寄存器的数据集被称为上下文),所以当执行到函数 b 时,可以通过longjmp 实现恢复 envbuf 的现场。