20.1 setjmp 和 longjmp 函数 20.1.1 函数介绍 #include <setjmp.h> int setjmp(jmp_buf env); 函数功能:设置非局部跳转的跳转点(设置跳转点) 返回值:直接调用返回0,若从 longjmp 调用返回则返回0 这个函数会被执行两次,一次是自己本身使用的时候返回0,另一次再调用 longjump 的时候,此函数再返回 longjmp 中的 val 值 #include <setjmp.h> void longjmp(j…
32.1 不可靠信号问题 发生信号时关联动作被重置为默认设置 信号可能丢失 程序片段 在进入 sig_int 与再次调用 signal 之间发生的 SIGINT 信号将不会捕获 导致进程终止 以前版本会由这个问题,当前的 Linux 版本是安全的 #include <signal.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> void sig_handler(int signo)…
22.1 fork 和 vfork 函数 22.1.1 函数说明 #include <unistd.h> #include <sys/types.h> pid_t fork( void); 函数说明: 一个现有进程可以调用fork函数创建一个新进程. 由fork创建的新进程被称为子进程(child process). fork函数被调用一次但返回两次. 两次返回的唯一区别是子进程中返回 0 值而父进程中返回子进程 ID. 子进程是父进程的副本,它将获得父进程数据空间.堆.栈等资源的…
22.2 父子进程操作文件 文件操作由两种模式: IO 系统调用操作文件 标准C IO 操作文件 看代码: #include <unistd.h> #include <string.h> #include <fcntl.h> #include <stdio.h> #include <stdlib.h> ;//全局变量,存放在数据段 int main(void) { ;//局部变量,调用的时候存放在栈中 ;//静态变量,存放在数据段 printf(…
使用库函数setjmp和longjmp可执行非局部跳转(local goto). 术语"非局部(nonlocal)"是指跳转目标为当前执行函数之外的某个位置. C语言里面有个"臭名昭著"的goto,每次介绍的时候都不忘了带一句,不要使用goto. C语言的goto存在一个限制,即不能从当前函数跳转到另一函数.然而,偶尔还是需要这一功能的.考虑错误处理中经常出现的如下场景:在一个深度嵌套的函数调用中发生了错误,需要放弃当前任务,从多层函数调用中返回,并在较高层级的函数…
转自 http://www.cnblogs.com/lienhua34/archive/2012/04/22/2464859.html C语言中有一个goto语句,其可以结合标号实现函数内部的任意跳转(通常情况下,很多人都建议不要使用goto语句,因为采用goto语句后,代码维护工作量加大).另外,C语言标准中还提供一种非局部跳转“no-local goto",其通过标准库<setjmp.h>中的两个标准函数setjmp和longjmp来实现. C标准库<setjmp.h>…
30.1 信号的基本概念 信号(signal)机制是Linux 系统中最为古老的进程之间的通信机制,解决进程在正常运行过程中被中断的问题,导致进程的处理流程会发生变化 信号是软件中断 信号是异步事件 不可预见 信号有自己的名称和编号 信号和异常处理机制 信号发生的来源 硬件来源:如按下键盘或其他硬件故障,信号是由驱动程序产生 软件来源:最常用发送信号的系统函数是 kill(),raise(),alarm() 和 setitimer() 等函数,软件来源还包括一些非法运算等操作,软件设置条件(如:…
18.1 进程的概念 程序:程序(program)是存放再磁盘文件中的可执行文件 进程 程序的执行实例被称为进程(process) 一个程序的执行实例可能由多个 进程具有独立的权限和职责.如果系统中某个进程崩溃,它不会影响到其余的进程. 每个进程运行在其各自的虚拟地址空间中,进程之间可以通过由内核控制的机制相互通讯 进程ID 每个 Linux 进程都一定由一个唯一的数字标识符,称为进程ID(process ID),进程ID总是一非负整数 18.2 内核中的进程结构体 每一个启动进程都有一个 ta…
34.1 信号特点 信号的发生是随机的,但信号在何种条件下发生是可预测的 进程杠开始启动时,所有信号的处理方式要么默认,要么忽略:忽略是 SIGUSR1 和 SIGUSR2 两个信号,其他都采取默认方式(大多数是终止进程). 进程在调用 exec 函数后,原有信号的捕捉函数失效 子进程的诞生总是继承父进程的信号处理方式 在系统层面上信号的发生是可靠的 在Linux 中的可靠性只保证一次,进程在处理信号期间,若发生同类型的信号不会丢失(内核会保留),会被延迟处理 但同类型信号的多次发生只会保留一次…
23.1 进程链和进程扇 23.1.1 概念 进程链:一个父进程构建出一个子进程,子进程再构建出子子进程,子子进程构建出子子子进程.... 这种就为进程链 进程扇:一个父进程构建出多个子进程,子进程都是由同一个父进程构建出来 23.1.2 进程链的构建 process_link.c /* 创建5个进程(包括父进程) */ #include <stdio.h> #include <stdlib.h> #include <unistd.h> int main(int arg…