信号(signal)用于通知进程发生了某种情况。
进程有以下3种处理信号的方式。
(1)忽略信号。有些信号表示硬件异常,例如,除以0或访问进程地址空间以外的存储单元等,因为这些异常产生的后果不确定,所以不推荐使用这种处理方式。
(2)按系统默认方式处理。对除数为0,系统默认方式是终止进程。
(3)提供一个函数,信号发生时调用该函数,这被称为捕抓该信号。通过提供自编的函数,我们就能知道什么时候产生了信号,并按期望的方式处理它。
实例:
从标准输入读命令并执行
#include "apue.h"
#include <sys/wait.h>
static void sig_int(int); // our signal-catching function
int main(void)
{
char buf[MAXLINE]; // from apue.h
pid_t pid;
int status;
if(signal(SIGINT, sig_int) == SIG_ERR)
err_sys("signal error");
printf("%%"); // print prompt (printf requires %% to print %)
while(fgets(buf, MAXLINE, stdin) != NULL){
if(buf[strlen(buf) - 1] == '\n')
buf[strlen(buf) - 1] = 0; // replace newline with null
if((pid = fork()) < 0){
err_sys("fork error");
}else if(0 == pid){ // child
execlp(buf, buf, (char *)0);
err_ret("couldn't execute: %s", buf);
exit(127);
}
// parent
if((pid = waitpid(pid, &status, 0)) < 0){
err_sys("waitpid error");
}
printf("%% ");
}
exit(0);
}
void sig_int(int signo)
{
printf("interrupt \n %% ");
}