Linux setjmp longjmp

/*********************************************************************
 *                      Linux setjmp longjmp
 * 说明:
 *     最近在看cmockery源代码的时候发现setjmp和longjmp函数,于是查了
 * 相关的内容,发现真是个好东西,可以完成函数之间的直接跳转。
 *
 *                                2016-5-7 深圳 南山平山村 曾剑锋
 ********************************************************************/

一、参考文章:
    1. C 语言中 setjmp 和 longjmp
        http://www.cnblogs.com/hazir/p/c_setjmp_longjmp.html
    2. setjmp(3) - Linux man page
        http://linux.die.net/man/3/setjmp

二、Demo:
    #include <stdio.h>
    #include <stdlib.h>
    #include <setjmp.h>

    int main(int argc, char *argv) {
        jmp_buf env;
        int i;

        i = setjmp(env);
        printf("i = %d.\n", i);
        printf("check position for exit before.\n");
        if ( i != 0 ) exit(0);

        printf("check position for exit after.\n");

        longjmp(env, 2);
        printf("This line does not get printed.\n");
    }

三、结果:
    myzr@myzr:~/c_program$ ./a.out
    i = 0.
    check position for exit before.
    check position for exit after.
    i = 2.
    check position for exit before.
    myzr@myzr:~/c_program$ 

 

时间: 2024-10-13 15:49:56

Linux setjmp longjmp的相关文章

浅析C语言中的setjmp与longjmp函数_C 语言

setjmp和longjmp是C语言独有的,只有将它们结合起来使用,才能达到程序控制流有效转移的目的,按照程序员的预先设计的意图,去实现对程序中可能出现的异常进行集中处理. 先来看一下这两个函数的定义吧: setjmp和longjmp的函数原型在setjmp.h中 函数原型:int setjmp(jmp_buf envbuf); setjmp函数用缓冲区envbuf保存系统堆栈的内容,以便后续的longjmp函数使用.setjmp函数初次启用时返回0值. void longjmp(jmp_buf

linux线程浅析

关于linux线程 在许多经典的操作系统教科书中, 总是把进程定义为程序的执行实例, 它并不执行什么, 只是维护应用程序所需的各种资源. 而线程则是真正的执行实体. 为了让进程完成一定的工作, 进程必须至少包含一个线程. 如图1. 进程所维护的是程序所包含的资源(静态资源), 如: 地址空间, 打开的文件句柄集, 文件系统状态, 信号处理handler, 等; 线程所维护的运行相关的资源(动态资源), 如: 运行栈, 调度相关的控制信息, 待处理的信号集, 等; 然而, 一直以来, linux内

Linux中线程和进程的区别

Linux中线程和进程的区别 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,它是系统进行资源分配和调度的一个独立单位.例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格.内存空间.磁盘空间.I/O设备等,然后该进程被放入到进程的就绪队列,进程调度程序选中它,为它分配CPU及其他相关资源,该进程就被运行起来. 线程是进程的一个实体,是CPU调度和分配的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器.一组寄存器和栈),但

linux线程的实现【转】

转自:http://www.cnblogs.com/zhaoyl/p/3620204.html   首先从OS设计原理上阐明三种线程:内核线程.轻量级进程.用户线程 内核线程 内核线程就是内核的分身,一个分身可以处理一件特定事情.这在处理异步事件如异步IO时特别有用.内核线程的使用是廉价的,唯一使用的资源就是内核栈和上下文切换时保存寄存器的空间.支持多线程的内核叫做多线程内核(Multi-Threads kernel ). 轻量级进程 轻量级线程(LWP)是一种由内核支持的用户线程.它是基于内核

C标准库参考指南(8)setjmp.h

8. setjmp.h 头文件setjmp用于控制底层调用和函数跳转. 宏: setjmp(); 函数: longjmp(); 变量: typedef jmp_buf 8.1. 变量和定义 变量jmp_buf是一个数组类型,用于存储setjmp和longjmp信息. 8.2. setjmp 声明: int setjmp(jmp_buf environment); 存储当前运行环境environment变量中.如果返回一个非零值,则表明longjmp到达了源码中所运行到的位置.否则表明运行环境已被

内存管理内幕

动态分配的选择.折衷和实现 Jonathan Bartlett (johnnyb@eskimo.com), 技术总监, New Media Worx 本文将对 Linux 程序员可以使用的内存管理技术进行概述,虽然关注的重点是 C 语言,但同样也适用于其他语言.文中将为您提供如何管理内存的细节,然后将进一步展示如何手工管理内存,如何使用引用计数或者内存池来半手工地管理内存,以及如何使用垃圾收集自动管理内存. 好文章收藏! 原文地址:http://www.ibm.com/developerwork

由mmap引发的SIGBUS(续)

关于之前的<由mmap引发的SIGBUS>问题,这几天又做了一些较深入的探索,整理如下. SIGBUS的必要性 为什么内核在上述情况下要抛出SIGBUS信号呢? 原来这是POSIX的规定,引用一段: The mmap() function can be used to map a region of memory that is larger than the current size of the object. Memory access within the mapping but be

缓冲区溢出:十年来攻击和防卫的弱点_漏洞研究

摘要: 在过去的十年中,以缓冲区溢出为类型的安全漏洞占是最为 常见的一种形式了.更为严重的是,缓冲区溢出漏洞占了远程网 络攻击的绝大多数,这种攻击可以使得一个匿名的Internet用户 有机会获得一台主机的部分或全部的控制权!如果能有效地消除 缓冲区溢出的漏洞,则很大一部分的安全威胁可以得到缓解.在 本文中,我们研究了各种类型的缓冲区溢出漏洞和攻击手段,同 时我们也研究了各种的防御手段,这些手段用来消除这些漏洞所 造成的影响,其中包括我们自己的堆栈保护方法.然后我们要考 虑如何在保证现有系统功能

C++中的异常(exception)

1.简介 异常是由语言提供的运行时刻错误处理的一种方式.提到错误 处理,即使不提到异常,你大概也已经有了丰富的经验,但是为了可以清楚的看 到异常的好处,我们还是不妨来回顾一下常用的以及不常用的错误处理方式. 1.1 常用的错误处理方式 返回值.我们常用函数的返回值来标志成功或 者失败,甚至是失败的原因.但是这种做法最大的问题是如果调用者不主动检查 返回值也是可以被编译器接受的,你也奈何不了他:) 这在C++中还导致另外一个 问题,就是重载函数不能只有不同的返回值,而有相同的参数表,因为如果调用