
1、忽略信号,即对信号不做任何处理,其中,有两个信号不能忽略,SIGKILL及SIGSTOP。
2、捕捉信号。定义信号处理函数,当信号发生时,执行相应的处理函数。
3、执行缺省 *** 作,Linux对每种信号都规定了默认 *** 作。
Linux下signal信号汇总
SIGHUP 1 /* Hangup (POSIX). / 终止进程 终端线路挂断
SIGINT 2 / Interrupt (ANSI). /终止进程 中断进程 Ctrl+C
SIGQUIT 3 / Quit (POSIX). /建立CORE文件终止进程,并且生成core文件 Ctrl+
SIGILL 4 / Illegal instruction (ANSI). / 建立CORE文件,非法指令
SIGTRAP 5 / Trace trap (POSIX). / 建立CORE文件,跟踪自陷
SIGABRT 6 / Abort (ANSI). /
SIGIOT 6 / IOT trap (4.2 BSD). / 建立CORE文件,执行I/O自陷
SIGBUS 7 / BUS error (4.2 BSD). / 建立CORE文件,总线错误
SIGFPE 8 / Floating-point exception (ANSI). / 建立CORE文件,浮点异常
SIGKILL 9 / Kill, unblockable (POSIX). / 终止进程 杀死进程
SIGUSR1 10 / User-defined signal 1 (POSIX). / 终止进程 用户定义信号1
SIGSEGV 11 / Segmentation violation (ANSI). / 建立CORE文件,段非法错误
SIGUSR2 12 / User-defined signal 2 (POSIX). / 终止进程 用户定义信号2
SIGPIPE 13 / Broken pipe (POSIX). / 终止进程 向一个没有读进程的管道写数据
SIGALARM 14 / Alarm clock (POSIX). / 终止进程 计时器到时
SIGTERM 15 / Termination (ANSI). / 终止进程 软件终止信号
SIGSTKFLT16 / Stack fault. /
SIGCLD SIGCHLD/ Same as SIGCHLD (System V). /
SIGCHLD 17 / Child status has changed (POSIX). /忽略信号 当子进程停止或退出时通知父进程
SIGCONT 18 / Continue (POSIX). /忽略信号 继续执行一个停止的进程
SIGSTOP 19 / Stop, unblockable (POSIX). / 停止进程 非终端来的停止信号
SIGTSTP 20 / Keyboard stop (POSIX). / 停止进程 终端来的停止信号 Ctrl+Z
SIGTTIN 21 / Background read from tty (POSIX). /停止进程 后台进程读终端
SIGTTOU 22 / Background write to tty (POSIX). / 停止进程 后台进程写终端
SIGURG 23 / Urgent condition on socket (4.2 BSD). /忽略信号 I/O紧急信号
SIGXCPU 24 / CPU limit exceeded (4.2 BSD). /终止进程 CPU时限超时
SIGXFSZ 25 / File size limit exceeded (4.2 BSD). / 终止进程 文件长度过长
SIGVTALRM26 / Virtual alarm clock (4.2 BSD). / 终止进程 虚拟计时器到时
SIGPROF 27 / Profiling alarm clock (4.2 BSD). / 终止进程 统计分布图用计时器到时
SIGWINCH 28 / Window size change (4.3 BSD, Sun). / 忽略信号 窗口大小发生变化
SIGPOLL SIGIO / Pollable event occurred (System V). /
SIGIO29 / I/O now possible (4.2 BSD). / 忽略信号 描述符上可以进行I/O
SIGPWR 30 / Power failure restart (System V). /
SIGSYS 31 / Bad system call. */
SIGUNUSED31
有两个信号可以停止进程:SIGTERM和SIGKILL。 SIGTERM 比较友好,进程能捕捉这个信号,根据您的需要来关闭程序。
在关闭程序之前,您可以结束打开的记录文件和完成正在做的任务。在某些情况下,假如进程正在进行作业而且不能中断,那么进程可以忽略这个SIGTERM信号。
对于 SIGKILL 信号,进程是不能忽略的。这是一个 “我不管您在做什么,立刻停止”的信号。假如您发送SIGKILL信号给进程,Linux就将进程停止在那里。
sigaddset 将信号signo 加入到信号集合之中;
sigdelset 将信号从信号集合中删除;
sigemptyset 函数初始化信号集合set,将set 设置为空;
sigfillset 也初始化信号集合,只是将信号集合设置为所有信号的集合;
linux的常用信号量BUS与SEGV二者都是错误信号,BUS表示总线错误,SEGV表示段错误,程序崩溃的时候99%都是这两个错误导致的。进程可以捕获和封锁这两类错误。内核对二者的默认处理是memorydumpWINCH窗口改变信号(WINdownCHanged)。例如虚拟终端的行数发生变化时将发送WINCH信号,绝大多数文本编辑器都能捕获WINCH信号自动进行重新配置。内核的默认处理是忽略该信号,并且不进行内存转储。进程可以捕获或者封锁该信号KILL 杀死/删除进程,编号为9STOP 挂起/暂停正在执行的进程,直到收到CONT为止KILLSTOP都不能够被捕获、封锁或者忽略,默认处理都不会产生内存转储。CONT 取消挂起,继续执行进程TSTP 是STOP信号的“软”版本,即在用户输入Ctrl+Z时由终端驱动程序发送的信号。捕获到该信号的进程通常清除它们的状态,如何给自己发送一个STOP信号。TSTP的默认处理不会导致内存转储。INT 中断信号,编号为2当用户输入Ctrl+C时由终端驱动程序发送INT信号INT信号是终止当前 *** 作的请求,简单程序捕获到INT信号时应该退出,拥有命令行或者输入模式的那些程序应该停止他们正在做的事情,清除状态,并等待用户再次输入。TERM 软件终止信号,编号为15TERM是请求彻底终止某项 *** 作的信号,它期望进程清楚自己的状态并退出QUIT 退出信号,编号为3与TERM类似,不同之处在于QUIT信号的默认处理是内存转储,而TERM信号的默认处理没有内存转储。HUP 挂起信号,编号为1,有两种解释:守护进程理解HUP为重新设置的请求,如果守护进程能够不用重新启动就能够重新读取它自己的配置文件并调整自己以适应变化的话,那么HUP信号通常可以用来触发这种行为HUP信号有时有终端驱动程序生成,试图用来清除(也就是终止)跟某个特定终端相连接的那些进程。例如当一个终端会话结束时,或者当一个Modem的连接不经意的断开时,就可能出现这种情况。如果需要某些进程在会话结束之后继续运行,那么在CShell中设法让这些进程变成后台程序,ksh或者bash中可以用nohup来模拟这种行为。++++++++++++++++++++++++++++++++++++++++++++++++++++++++++进程的四种状态runnable(可运行状态)只要有CPU时间,进程就可以执行。一旦进程执行了不能立即完成的系统调用,Linux会把进程转入睡眠状态sleeping(睡眠状态)进程在等待某些事件发生(如终端输入、网络连接)zombie(僵化状态)进程已经执行完毕并试图消亡,但是状态没有收集完stopped(停止状态)进程被挂起,不允许执行。进程收到STOP或者TSTP信号即进入停止状态,可以用CONT信号来重新启动欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)