1.信号类型
信号事件的发生有两个来源:硬件来源和软件来源。
下面是几种常见的信号:
§ SIGHUP: 从终端上发出的结束信号
§ SIGINT: 来自键盘的中断信号(Ctrl-C)
§ SIGSTOP:来自键盘(Ctrl-Z)或调试程序的停止执行信号,暂停进程
§ SIGKILL:该信号结束接收信号的进程,杀死进程
§ SIGTERM:kill 命令发出的信号
§ SIGCHLD:子进程停止或结束时通知父进程
2.信号处理方式
当某信号出现时,将按照下列三种方式中
的一种进行处理:
1)、忽略此信号
大多数信号都按照这种方式进行处理,但有两种信号决不能被忽略,它们是:
SIGKILL\SIGSTOP。
这两种信号不能被忽略的原因是:它们向超级用户提供了一种终止或停止进程的方法
2)、执行用户希望的动作
通知内核在某种信号发生时,调用一个用户函数。在用户函数中,执行用户希望的处理
3)、执行系统默认动作
对大多数信号的系统默认动作是终止该进程
3.信号函数
1)kill
函数作用:传送信号给指定的进程
函数原型:int kill(pid_t pid, int signo)
参数:
pid参数有四种不同的情况:
1、pid>0
将信号发送给进程ID为pid的进程。
2、pid == 0
将信号发送给同组的进程。
3、pid < 0
将信号发送给其进程组ID等于pid绝对值的进程。
4、pid ==-1
将信号发送给所有进程
返回值:成功为0,失败为-1;
头文件:
#include <sys/types.h>
#include <signal.h>
函数例子:
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <sys/types.h>
#include <sys/wait.h>
int main()
{
pid_t pid;
int ret;
if((pid=fork()) < 0)
{
perror("fork");
exit(1);
}
if(pid == 0)
{
raise(SIGSTOP);
exit(0);
}
else
{
printf("pid=%d\n", pid);
if((waitpid(pid, NULL, WNOHANG)) == 0)
{
kill(pid,SIGKILL);
printf("kill %d\n", pid);
}
else
{
perror("kill");
}
}
}
执行结果:
pid=25831
kill 25831
找到进程号,并且杀死该进程。
2.raise
函数作用:发送信号给自身
函数原型:int raise(int signo)
返回值:成功为0,失败为-1;
头文件:
#include <sys/types.h>
#include <signal.h>
程序例子
#include <sys/types.h>
#include <sys/stat.h>
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <signal.h>
#include <sys/wait.h>
int main()
{
pid_t pid;
int ret;
if((pid= fork()) < 0)
{
printf("Fork error.\n");
exit(-1);
}
if(pid == 0)
{
printf("child (pid:%d) is waiting for any signal\n.", getpid());
raise(SIGSTOP);
exit(0);
}
else
{
if((waitpid(pid, NULL, WNOHANG)) == 0)
{
kill(pid, SIGKILL);
printf("parent kill child process %d\n", pid);
}
waitpid(pid, NULL, 0);
exit(0);
}
}
执行结果
child (pid:25923) is waiting for any signal
parent kill child process 25923
子进程等待该进程的信号,父进程杀死子进程。
3.alarm
函数作用:设置信号传送时钟
函数原型:unsigned int alarm(unsigned int seconds)
参数:seconds: 经过了指定的seconds秒后会产生信号SIGALRM。
返回值:成功为0,失败为-1;
头文件:
#include <sys/types.h>
#include <signal.h>
4.pause
函数作用:让进程暂停直到信号出现
函数原型:int pause(void)
说明:令目前进程暂停进入睡眠状态,直到被信号中断
头文件:
#include <unistd.h>
5.signal
函数作用:设置信号处理方式
函数原型:void (*signal (int signo, void (* sighandler_t)(int)))(int)
说明:如何理解?
typedef void (*sighandler_t)(int) sighandler_t ;
sighandler_t signal(int signum, sighandler_t handler))
func可能的值是:
1、SIG_IGN:忽略此信号
2、SIG_DFL: 按系统默认方式处理
3、信号处理函数名:使用该函数处理
头文件:
#include <sinal.h>