Linux下的信号名以SIG开头,如:SIGSEGV 段错误、SIGTERM 退出 等等,它们都在头文件<signal.h>中定义信号名和对应的值,并且信号的值都大于0。产生信号的原因:1.硬件异常:除零出错、无效内存的引用,如SIGSEGV表示进程访问了无效的内存地址2.软件发送的信号:如SIGPIPE表示进程尝试写入到没有阅读的管道(或socket)时,SIGALRM进程计时器到期3.用户按下某些终端按键:如按下Ctrl+C,产生SIGINT信号,停止进程,按下Ctrl+Z产生SIGTSTR信号,挂起前台进程组4.通过Kill命令向特定进程发送信号5.通过raise函数,向自身发送信号对于信号的处理也有几种常见的方式:1.可以忽略信号,除了SIGKILL和SIGSTOP外,其它的信号都可以由程序忽略2.可以应用信号的默认操作,大多数信号的默认操作是结束进程,比如SIGTERM、SIGPIPE;SIGSEGV的默认操作是触发core dump,产生核心转储文件,便于进行debug3.可以捕获信号, 比如当接收到SIGTERM时,对程序进行结束前的收尾工作,关闭文件描述符、socket,释放资源,删除临时文件;当接收到SIGCHLD时,调用waitpid获得子进程的PID,并获取它的退出码 常见的信号、说明和默认操作: SIGABRT 异常终止 coredump SIGALRM 报警计时器超时 终止 SIGBUS 总线错误 coredump SIGCANCEL 取消信号 忽略SIGCHLD 子进程状态改变 忽略 SIGCLD SIGCHLD的别名 忽略SIGCONT 继续已停止的进程 忽略SIGEMT 仿真进程陷阱 忽略SIGFPE 算术异常 coredumpSIGFREEZE 检查点冻结 忽略SIGHUP 挂断 终止 SIGILL 非法指令 coredumpSIGINT 终端中断字符ctrl+c 终止 SIGIO SIGPOLL的别名 终止SIGIOT SIGABRT的别名 coredumpSIGKILL 杀死进程 终止 SIGLOST 资源丢失 终止SIGPIPE 写入没有阅读程序的管道 终止 SIGPOLL 可轮询事件已经发生 终止SIGPROF 记录计时器到期 终止SIGPWR 电源失效或重新启动 忽略SIGQUIT 终端退出字符 coredump SIGSEGV 段错误 coredump SIGSTOP 停止 停止进程 SIGSYS 存在错误的系统调用 coredumpSIGTERM 终止进程 终止 SIGTHAW 检查点解冻 忽略SIGTRAP 跟踪或断点陷阱 coredumpSIGTSTP 终端挂起符ctrl+z 停止进程SIGTTIN 对控制台的TTY的后台读取 停止进程SIGTTOU 后台写入控制的TTY 停止进程SIGURG 紧急套接字条件 忽略SIGUSR1 用户自定义信号1 终止SIGUSR2 用户自定义信号2 终止SIGVTALRM 虚拟计时器报警 终止SIGWAITING 并发的信号 忽略SIGWINCH 终端窗口尺寸改变 忽略SIGXCPU 超出cpu限制 coredumpSIGFSZ 超出文件尺寸限制 coredumpSIGXRES 超出资源控制 忽略