C语言标准库中的 <setjmp.h> 头文件提供了一种非局部跳转的方法
▥编程
𝄐 0
c语言标准库大全,c语言标准库函数大全,c语言标准库源码,c语言的标准库中的函数名有哪些,c语言setprecision,c语言常用标准库
C语言标准库中的 <setjmp.h> 头文件提供了一种非局部跳转的方法。这意味着它允许程序在执行过程中从一个函数中跳转到其调用者之外的位置,比如从一个嵌套的递归函数中退出到某个特定的点。
这个头文件中最重要的函数是 setjmp() 和 longjmp() 。setjmp() 函数设置一个保存点,将当前状态保存到一个缓冲区,并返回 0 。而 longjmp() 函数接受一个保存点并恢复该保存点所代表的状态,使程序回到该保存点,并立即返回指定的值。
以下是一个简单的例子,演示如何使用 setjmp() 和 longjmp() 函数:
#include <stdio.h>
#include <setjmp.h>
jmp_buf buf;
void second() {
printf("second\n");
longjmp(buf,1); // 返回到 setjmp()
}
void first() {
second();
printf("first\n"); // 不会被执行
}
int main() {
if (setjmp(buf)) {
printf("main\n"); // 由 longjmp() 跳转回来
}
else {
first(); // 第一次调用 setjmp()
}
return 0;
}
在上面的例子中,当程序运行到 setjmp() 函数时,它会将当前状态保存到 buf 缓冲区,并返回 0 。然后程序调用了 first() 函数,该函数又调用了 second() 函数。在 second() 函数中,程序调用了 longjmp() 函数,并传递了 buf 和 1 作为参数。这会使程序跳转回到 setjmp() 函数的代码处,并返回 1 。因为我们已经设置了缓冲区,所以控制权将被转移到缓冲区所代表的上下文,而不是从函数调用链的最后一个函数返回。这样,程序就可以直接执行 main() 函数中来自 longjmp() 的输出语句。
C语言标准库中的 <setjmp.h> 头文件提供了一种非局部跳转的方法。这意味着它允许程序在执行过程中从一个函数中跳转到其调用者之外的位置,比如从一个嵌套的递归函数中退出到某个特定的点。
这个头文件中最重要的函数是 setjmp() 和 longjmp() 。setjmp() 函数设置一个保存点,将当前状态保存到一个缓冲区,并返回 0 。而 longjmp() 函数接受一个保存点并恢复该保存点所代表的状态,使程序回到该保存点,并立即返回指定的值。
以下是一个简单的例子,演示如何使用 setjmp() 和 longjmp() 函数:
#include <stdio.h>
#include <setjmp.h>
jmp_buf buf;
void second() {
printf("second\n");
longjmp(buf,1); // 返回到 setjmp()
}
void first() {
second();
printf("first\n"); // 不会被执行
}
int main() {
if (setjmp(buf)) {
printf("main\n"); // 由 longjmp() 跳转回来
}
else {
first(); // 第一次调用 setjmp()
}
return 0;
}
在上面的例子中,当程序运行到 setjmp() 函数时,它会将当前状态保存到 buf 缓冲区,并返回 0 。然后程序调用了 first() 函数,该函数又调用了 second() 函数。在 second() 函数中,程序调用了 longjmp() 函数,并传递了 buf 和 1 作为参数。这会使程序跳转回到 setjmp() 函数的代码处,并返回 1 。因为我们已经设置了缓冲区,所以控制权将被转移到缓冲区所代表的上下文,而不是从函数调用链的最后一个函数返回。这样,程序就可以直接执行 main() 函数中来自 longjmp() 的输出语句。
本文地址:
/show-278556.html
版权声明:除非特别标注原创,其它均来自互联网,转载时请以链接形式注明文章出处。