【linux高级程序设计】(第十章)Linux异步信号处理机制

发送信号

在终端用kill命令杀死当前终端

r

如上, 使用 kill -SIGCONT 2563 时,终端忽略了该信号

使用 kill -SIGABRT 2563 时,终端退出。需要重新输入用户名密码登陆。

int kill (__pid_t __pid, int __sig) :向指定进程发送信号。第一个参数为要传递信号的进程号,第二个参数为发送的信号值。

int raise (int __sig) :给当前进程发一个信号,即唤醒一个进程.成功返回0,否则返回-1.

  等价于

if(kill(getpid(), int __sig) == -1)
    perror("raise");

  使用raise函数

if(raise(SIGUSR1)!= 0)
    perror("Failed to raise SIGUSR1");

unsigned int alarm (unsigned int __seconds) :在指定时间内产生SIGALRM信号给当前进程。此函数每调用一次,产生一个信号,并不是循环产生信号的。默认接收到该信号后进程终止执行。

时间: 2024-10-12 20:01:54

【linux高级程序设计】(第十章)Linux异步信号处理机制的相关文章

【linux高级程序设计】(第十二章)Linux多线程编程 4

读写锁 书上有读者写者的代码,我实在是懒得实现一遍了.跟之前的代码差不多. 多线程异步信号处理 int pthread_kill (pthread_t __threadid, int __signo) :发送信号.第二个参数为0时表示检测指定线程是否存在.成功返回0. int pthread_sigmask (int __how, __const __sigset_t *__restrict __newmask, __sigset_t * __restrict __oldmask) :设置调用线

Linux程序设计学习笔记——异步信号处理机制

转载请注明出处: http://blog.csdn.net/suool/article/details/38453333 Linux常见信号与处理 基本概念 Linux的信号是一种进程间异步的通信机制,在实现上一种软中断.信号能够导致一个正在执行的进程被异步打断,转而去处理一个突发事件.异步事件不可预知,仅仅能通过一些特定方式预防.或者说,当该异步事件发生时依据原来的设定完毕对应的操作. 信号本质 信号是在软件层次上对中断机制的一种模拟.在原理上,一个进程收到一个信号与处理器收到一个中断请求能够

【linux高级程序设计】(第十五章)UDP网络编程应用 4

socket信号驱动 为了使一个套接字能够使用信号驱动I/O,至少需要以下3步操作. 1.安装SIGIO信号 2.套接字的拥有者设定为当前进程.因为SIGIO信号只会送到socket拥有者进程. 通过fcntl的F_SETOWN 3.套接字必须被允许使用异步I/O. 通过fcntl的F_SETFL,设置为O_ASYNC 在UDP通信中,下面情况会产生SIGIO信号 在TCP通信中,下面情况会产生SIGIO信号 例子: 下面的代码好奇怪,说是UDP的,但是发送接收用的是send, recv 而且客

【linux高级程序设计】(第十一章)System V进程间通信 1

System V, 曾经也被称为 AT&T System V,是Unix操作系统众多版本中的一支. 传统上,System V 被看作是两种UNIX"风味"之一(另一个是 BSD).然而,随着一些并不基于这两者代码的UNIX实现的出现,例如 Linux 和 QNX, 这一归纳不再准确. System V IPC基础 System V 的IPC机制主要有消息队列.信号量和共享内存3种机制. shell中的 ipcs 命令可以查看当前系统中正在使用的IPC工具. shell中的 ip

【linux高级程序设计】(第十二章)Linux多线程编程

线程与进程对比 1.用户空间对比 2.内核空间资源对比 在创建线程时,Linux内核仍然创建一个新的PCB来标识这个线程.内核并不认为进程与线程有差别. 进程是操作系统管理资源的基本单元,线程时Linux系统调度的基本单元. 3.进程线程函数对比 创建线程 int pthread_create (pthread_t *__restrict __newthread, __const pathread_attr_t *__restrict __attr, void *(*__start_routin

【linux高级程序设计】(第十四章)TCP高级应用

文件I/O方式比较 1.阻塞式文件I/O 进程从调用函数开始,直到返回这段时间都处于阻塞状态. 2.非阻塞式文件I/O 如果当前没有数据可操作,将不阻塞当前进程,而是立即返回一个错误信息.需要反复尝试. 3.多路复用I/O 仍然是阻塞方式等待,但是可以同时等待多个文件描述符. 4.信号驱动I/O 异步方式,等到数据准备好后通知处理进程,不需要重复询问,效率高. I/O阻塞与非阻塞操作 阻塞方式:默认情况下read/write和 把flag设为0的recv/send 非阻塞方式:如果没有数据,立刻

【linux高级程序设计】(第十五章)UDP网络编程应用 2

UDP广播通信 单播:一对一,TCP和UDP均可完成 广播:只能UDP完成.广播时发送方只发送一个数据包,但是网络上的交换机默认转发广播数据包到所有端口.路由器默认不转发任何广播数据包.故广播在局域网范围内. 组播:只有UDP可以完成.发送消息到同一个组播组的主机.视频电话.视频会议多采用. 广播IP地址:主机号全1.网络号正常 广播MAC地址:全1,即FF:FF:FF:FF:FF:FF 广播数据帧格式 处理过程: 网卡驱动程序对比自己的MAC地址与目的MAC地址,发现是广播MAC地址,统一接收

【linux高级程序设计】(第十一章)System V进程间通信 4

共享内存 共享内存主要用于实现进程间大量数据传输. 共享内存的数据结构定义: 系统对共享内存的限制: 共享内存与管道的对比: 可以看到,共享内存的优势: 1.共享内存只需复制2次,而管道需要4次 2.共享内存不需要切换内核态与用户态,而管道需要. 共享内存效率高! int shmget (key_t __key, size_t __size, int __shmflg) :创建共享内存 第一个参数:key值 第二个参数:欲创建的共享内存段的大小(字节) 第三个参数:shmflg创建标识,包括IP

【linux高级程序设计】(第十一章)System V进程间通信 3

信号量通信机制 可以看到,跟消息队列类似,也是包括两个结构. int semget (key_t __key, int __nsems, int __semflg) : 创建信号量集合 第一个参数:ftok产生的key值 第二个参数:创建的信号量个数 第三个参数:权限信息 创建信号量例子: #include<stdio.h> #include<unistd.h> #include<stdlib.h> #include<sys/ipc.h> #include&