setjump和longjmp函数

1、setjmp和longjmp函数特点

此两函数所处头文件<setjmp.h>,弥补了C语言有限的转移能力,其必须协同工作,工作特点如下:

i、记录:setjmp(jmp_buf j)必须首先调用,表示“使用变量j记录现在的位置。函数返回零。”

ii、转移:longjmp(jmp_buf j,int i)可以接着调用。表示“回到j所记录的位置,让它看上去像是原先的setjmp()函数返回一样。但是函数返回i,使代码能够知道它是实际上是通过longjmp()返回。”

iii、销毁:当使用longjmp()时,j的内容被销毁。

setjmp保存了一份程序的计数器和当前的栈顶指针。如果喜欢也可以保存一些初始值。longjmp恢复这些值,有效地转移控制并把状态重置回保存状态的时候。

与goto语名的区别:goto不能跳出C语言当前的函数,而longjmp如其名,可以长长的跳过去,甚至可以跳到其他文件的函数中。

longjmp也有特点,只能跳回曾经到过的地方。因为在执行setjmp的地方仍留有一个过程活动记录。longjmp接受一个额外的整形参数并返回它的值。

以下是举例:

#include<setjmp.h>
#include<stdio.h>

jmp_buf buf;

void banana(){
	printf("in banana()\n");
	longjmp(buf,1);//回到buf所记录的位置,并返回1,同时buf的内容被销毁
	/* the code can't be processed*/
	printf("youo'll never see this, because i longjmp'd");
}
void main(){
	if(setjmp(buf))//1、使用变量buf记录现在位置,并返回零
		printf("back in main\n");
	else{
		printf("first time through\n");
		banana();
	}
}



//输出结果:
first time through
in banana()
back in main

猜你喜欢

转载自blog.csdn.net/TT_love9527/article/details/81517498