setjmp库里的函数:void longjmp (jmp_buf env, int val)和int setjmp(jmp_buf env)
void longjmp (jmp_buf env, int val)的使用:恢复env
所指的缓冲区中的程序调用环境上下文,env
所指缓冲区的内容是由setjmp
子程序,调用所保存。value
的值从longjmp
传递给setjmp
。longjmp
完成后,程序从对应的setjmp
调用处继续执行,如同setjmp
调用刚刚完成。如果value
传递给longjmp
零值,setjmp
的返回值为1;否则,setjmp
的返回值为value
。
int setjmp(jmp_buf env)的使用:建立本地的jmp_buf
缓冲区并且初始化,用于将来跳转回此处。这个子程序保存程序的调用环境于env
参数所指的缓冲区,env
将被longjmp
使用。如果是从setjmp
直接调用返回,setjmp
返回值为0。如果是从longjmp
恢复的程序调用环境返回,setjmp
返回非零值
例子
#include <stdio.h>
#include <setjmp.h>
static jmp_buf buf;
void second(void) {
printf("second\n"); // 打印
longjmp(buf,1); // 跳回setjmp的调用处 - 使得setjmp返回值为1
}
void first(void) {
second();
printf("first\n"); // 不可能执行到此行
}
int main() {
if ( ! setjmp(buf) ) {
first(); // 进入此行前,setjmp返回0
} else { // 当longjmp跳转回,setjmp返回1,因此进入此行
printf("main\n"); // 打印
}
return 0;
}
上述程序将输出:
second
main
例子解释:注意到虽然first()子程序被调用,"first"不可能被打印。"main"被打印,因为条件语句if ( ! setjmp(buf) )被执行第二次