大家好,我是本期栏目编辑小友,现在为大家讲解linux信号signal处理函数问题。
一、闹钟(设置信号传输闹钟)。
相关函数信号,睡眠。
头文件# includeinstd.h。
定义了函数无符号整数报警(无符号整数秒)。
功能报警()用于设置信号SIGALRM在参数秒指定的秒数后传输到当前进程。如果参数秒为0,先前设置的闹钟将被取消,剩余时间将被返回。
返回前一个闹钟的剩余秒数,如果之前没有设置闹钟,则返回0。
示例# includeinstd.h
#includesignal.h
void handler(){ 0
printf(' hello \ n ');
}
main()
{
int I;
信号(SIGALRM,处理程序);
警报(5);
for(I=1;i7;I){ 0
printf('睡眠%d.\n ',I);
睡眠(1);
}
}
执行睡眠1.
睡眠2.
睡眠3.
睡眠4.
睡眠5.
你好
睡眠6.
二、kill(向指定进程发送信号)。
相关功能上升,信号。
头文件# include sys/type . h。
#includesignal.h
定义函数int kill(pid_t pid,int SIG);
解释函数kill()可用于将参数sig指定的信号发送到参数pid指定的进程。pid :参数有几种情况。
0 pid将信号发送给进程标识为pid的进程。
Pid=0将信号传输到与当前进程在同一进程组中的所有进程。
Pid=-1将信号广播传输到系统中的所有进程。
0 pid向进程组id为pid绝对值的所有进程发送信号。
参数sig代表的信号编号见附录d。
如果返回值执行成功,将返回0,如果有错误,将返回-1。
错误代码EINVAL参数签名非法。
由ESRCH参数pid指定的流程或流程组不存在。
EPERM没有足够的权限向指定的进程发送信号。
示例# includeinstd.h
#includesignal.h
#包括系统/类型. h
#includesys/wait.h
main()
{
pid _ t pid
int状态;
if(!(PID=fork())){ 0
printf('Hi我是子进程!\ n ');
睡眠(10);
返回;
}
else{
printf('发送信号给子进程(%d) \n ',PID);
睡眠(1);
kill(pid、SIGABRT);
等待(状态);
if(WIPHILED(状态))
printf('智利进程接收信号%d\n ',WTERMSIG(状态));
}
}
执行发送信号给子进程(3170)。
嗨我是孩子的过程!
子进程接收信号6
第三,暂停(暂停过程,直到信号出现)。
相关功能杀,信号,睡眠。
头文件# includeinstd.h。
定义函数int pause(void);
解释函数pause()将暂停当前进程(进入睡眠状态),直到被信号中断。
返回值只返回-1。
错误代码EINTR,一个信号到达并中断了该功能。
信号操作(查询或设置信号处理模式)
相关函数信号。
suspend表头文件 #include<signal.h>
定义函数 int sigacTIon(int signum,const struct sigacTIon *act ,struct sigacTIon *oldact);
函数说明 sigaction()会依参数signum指定的信号编号来设置该信号的处理函数。参数signum可以指定SIGKILL和SIGSTOP以外的所有信号。
如参数结构sigaction定义如下
struct sigaction
{
void (*sa_handler) (int);
sigset_t sa_mask;
int sa_flags;
void (*sa_restorer) (void);
}
sa_handler此参数和signal()的参数handler相同,代表新的信号处理函数,其他意义请参考signal()。
sa_mask 用来设置在处理该信号时暂时将sa_mask 指定的信号搁置。
sa_restorer 此参数没有使用。
sa_flags 用来设置信号处理的其他相关操作,下列的数值可用。
OR 运算(|)组合
A_NOCLDSTOP : 如果参数signum为SIGCHLD,则当子进程暂停时并不会通知父进程
SA_ONESHOT/SA_RESETHAND:当调用新的信号处理函数前,将此信号处理方式改为系统预设的方式。
SA_RESTART:被信号中断的系统调用会自行重启
SA_NOMASK/SA_NODEFER:在处理此信号未结束前不理会此信号的再次到来。
如果参数oldact不是NULL指针,则原来的信号处理方式会由此结构sigaction 返回。
返回值 执行成功则返回0,如果有错误则返回-1。
错误代码 EINVAL 参数signum 不合法,或是企图拦截SIGKILL/SIGSTOPSIGKILL信号
EFAULT 参数act,oldact指针地址无法存取。
EINTR 此调用被中断
范例 #include<unistd.h>
#include<signal.h>
void show_handler(struct sigaction * act)
{
switch (act->sa_flags)
{
case SIG_DFL:printf("Default action\n");break;
case SIG_IGN:printf("Ignore the signal\n");break;
default: printf("0x%x\n",act->sa_handler);
}
}
main()
{
int i;
struct sigaction act,oldact;
act.sa_handler = show_handler;
act.sa_flags = SA_ONESHOT|SA_NOMASK;
sigaction(SIGUSR1,&act,&oldact);
for(i=5;i<15;i++)
{
printf("sa_handler of signal %2d =".i);
sigaction(i,NULL,&oldact);
}
}
执行 sa_handler of signal 5 = Default action
sa_handler of signal 6= Default action
sa_handler of signal 7 = Default action
sa_handler of signal 8 = Default action
sa_handler of signal 9 = Default action
sa_handler of signal 10 = 0x8048400
sa_handler of signal 11 = Default action
sa_handler of signal 12 = Default action
sa_handler of signal 13 = Default action
sa_handler of signal 14 = Default action
四、sigaddset(增加一个信号至信号集)
相关函数 sigemptyset,sigfillset,sigdelset,sigismember
表头文件 #include<signal.h>
定义函数 int sigaddset(sigset_t *set,int signum);
函数说明 sigaddset()用来将参数signum 代表的信号加入至参数set 信号集里。
返回值执行成功则返回0,如果有错误则返回-1。
错误代码 EFAULT 参数set指针地址无法存取
EINVAL 参数signum非合法的信号编号
五、sigdelset(从信号集里删除一个信号)
相关函数 sigemptyset,sigfillset,sigaddset,sigismember
表头文件 #include<signal.h>
定义函数 int sigdelset(sigset_t * set,int signum);
函数说明 sigdelset()用来将参数signum代表的信号从参数set信号集里删除。
返回值 执行成功则返回0,如果有错误则返回-1。
错误代码 EFAULT 参数set指针地址无法存取
EINVAL 参数signum非合法的信号编号
六、sigemptyset(初始化信号集)
相关函数 sigaddset,sigfillset,sigdelset,sigismember
表头文件 #include<signal.h>
定义函数 int sigemptyset(sigset_t *set);
函数说明 sigemptyset()用来将参数set信号集初始化并清空。
返回值 执行成功则返回0,如果有错误则返回-1。
错误代码 EFAULT 参数set指针地址无法存取
七、sigfillset(将所有信号加入至信号集)
相关函数 sigempty,sigaddset,sigdelset,sigismember
表头文件 #include<signal.h>
定义函数 int sigfillset(sigset_t * set);
函数说明 sigfillset()用来将参数set信号集初始化,然后把所有的信号加入到此信号集里。
返回值 执行成功则返回0,如果有错误则返回-1。
附加说明 EFAULT 参数set指针地址无法存取
八、sigismember(测试某个信号是否已加入至信号集里)
相关函数 sigemptyset,sigfillset,sigaddset,sigdelset
表头文件 #include<signal.h>
定义函数 int sigismember(const sigset_t *set,int signum);
函数说明 sigismember()用来测试参数signum 代表的信号是否已加入至参数set信号集里。如果信号集里已有该信号则返回1,否则返回0。
返回值信号集已有该信号则返回1,没有则返回0。如果有错误则返回-1。
错误代码 EFAULT 参数set指针地址无法存取
EINVAL 参数signum 非合法的信号编号
九、signal(设置信号处理方式)
相关函数 sigaction,kill,raise
表头文件 #include<signal.h>
定义函数 void (*signal(int signum,void(* handler)(int)))(int);
函数说明 signal()会依参数signum 指定的信号编号来设置该信号的处理函数。当指定的信号到达时就会跳转到参数handler指定的函数执行。如果参数handler不是函数指针,则必须是下列两个常数之一:
SIG_IGN 忽略参数signum指定的信号。
SIG_DFL 将参数signum 指定的信号重设为核心预设的信号处理方式。
关于信号的编号和说明,请参考附录D
返回值返回先前的信号处理函数指针,如果有错误则返回SIG_ERR(-1)。
附加说明在信号发生跳转到自定的handler处理函数执行后,系统会自动将此处理函数换回原来系统预设的处理方式,如果要改变此操作请改用sigaction()。
范例 参考alarm()或raise()。
十、sigpending(查询被搁置的信号)
相关函数 signal,sigaction,sigprocmask,sigsuspend
表头文件 #include<signal.h>
定义函数 int sigpending(sigset_t *set);
函数说明 sigpending()会将被搁置的信号集合由参数set指针返回。
返回值执 行成功则返回0,如果有错误则返回-1。
错误代码 EFAULT 参数set指针地址无法存取
EINTR 此调用被中断。
十一、sigprocmask(查询或设置信号遮罩)
相关函数 signal,sigaction,sigpending,sigsuspend
表头文件 #include<signal.h>
定义函数 int sigprocmask(int how,const sigset_t *set,sigset_t * oldset);
函数说明 sigprocmask()可以用来改变目前的信号遮罩,其操作依参数how来决定
SIG_BLOCK 新的信号遮罩由目前的信号遮罩和参数set 指定的信号遮罩作联集
SIG_UNBLOCK 将目前的信号遮罩删除掉参数set指定的信号遮罩
SIG_SETMASK 将目前的信号遮罩设成参数set指定的信号遮罩。
如果参数oldset不是NULL指针,那么目前的信号遮罩会由此指针返回。
返回值 执行成功则返回0,如果有错误则返回-1。
错误代码 EFAULT 参数set,oldset指针地址无法存取。
EINTR 此调用被中断
十二、sleep(让进程暂停执行一段时间)
相关函数 signal,alarm
表头文件 #include<unistd.h>
定义函数 unsigned int sleep(unsigned int seconds);
函数说明 sleep()会令目前的进程暂停,直到达到参数seconds 所指定的时间,或是被信号所中断。
返回值 若进程暂停到参数seconds 所指定的时间则返回0,若有信号中断则返回剩余秒数。
标签:
版权声明:转载此文是出于传递更多信息之目的。若有来源标注错误或侵犯了您的合法权益,请作者持权属证明与本网联系,我们将及时更正、删除,谢谢您的支持与理解。