您好,登录后才能下订单哦!
本篇文章和大家了解一下Linux中signal()函数怎么使用。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
无意中看到了 signal() 函数,感觉对这个函数的原型有诸多疑惑,学习一下,顺便分享。
Unix系统提供了signal()和sigaction()两个函数来改变对于信号的处理方法。其中signal()是一个基于sigaction()系统调用的glibc库函数,其行为在不同的Unix操作系统存在差异,对于可移植性有要求的程序不能使用signal()函数。
其原型如下:
#include<signal.h> void ( *signal(int sig, void (*handler)(int)) )(int);
signal函数的第一个参数sig,要传入希望修改处理函数的信号编号,第二个参数,是一个无返回值、接受一个int形参的函数指针,指向对sig信号的新处理函数。函数的第二个参数可以有三种选择,第一种是我们自己定义的信号处理函数,第二种是传入SIG_DFL 表示将之前signal所改变的信号处理方式还原,第三种是传入SIG_IGN,表示处理方式为忽略该信号,内核会直接将信号丢弃,不会传递到进程。
signal函数的返回值同样是一个无返回值、接受一个int形参的函数指针。当signal()函数成功执行时,返回值是执行signal函数之前的sig信号的处理函数的指针,如果失败,则返回SIG_ERR。
对信号处理函数指针做这样的定义,可能便于理解:
//将sighandler_t定义为返回值为void,接受一个int形参的函数的指针 typedef void (*sighandler_t)(int); //现在我们可以这样书写signal函数 sighandler_t signal(int sig, sighandler_t handler);
其实glibc里已经有了如上的定义,只需要我们定义_GUN_SOURCE特性测试宏,就可以使用sighandler_t类型。
以下用法用于暂时性修改某信号的信号处理函数,在使用完之后,将信号处理函数重置为其原来版本。
void newhandler(int sig){ //code to handle the sig } void (*prevhandler)(int); //存储修改之前的信号处理函数 prehandler = signal(SIGINT, newhandler); if(prehandler == SIG_ERR) cerr<<"Error in signal"<<endl; /*现在,对于中断信号的处理已经修改为我们定义的newhandler函数*/ if(signal(SIGINT, prevhandler) == SIG_ERR) cerr<<"Error in signal"<<endl;
以上就是Linux中signal()函数怎么使用的简略介绍,当然详细使用上面的不同还得要大家自己使用过才领会。如果想了解更多,欢迎关注亿速云行业资讯频道哦!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。