Unix环境高级编程(阅读笔记)----sigaction函数
2016-05-12 16:43
295 查看
sigaction函数的功能是检查或修改指定信号相关联的处理动作,此函数取代UNIX早期版本使用的signal函数。
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/9e12f1d3e499fc949c886e7c9e0484f9)
#include<signal.h>
int sigaction(int signo, const struct sigaction *restrict act, struct sigaction *restrict oact);
//若成功则返回0,出错则返回-1.
参数signo是要检测或修改其具体动作的信号编号。
若act指针非空,则要修改其动作;如果oact指针非空,则系统经由oact指针返回该信号的上一个动作,此函数使用如下结构:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/9e12f1d3e499fc949c886e7c9e0484f9)
struct sigaction{
void (*sa_handler)(int); //信号捕捉函数的地址或者SIG_IGN,或者SIG_DFL
sigset_t sa_mask; //在调用信号捕捉函数之前要屏蔽的信号,当从信号步骤函数返回时,将进程信号屏蔽字复原。
//操作系统建立的新信号屏蔽字包含正在被递送的信号。
int sa_flags; //信号选项
void (*sa_sigaction)(int, siginfo_t*, void*); //替代信号处理函数地址
}
act结构的sa_flags字段指定对信号处理的各个选项。
![](https://oscdn.geek-share.com/Uploads/Images/Content/202011/14/d826b496ca3a9f535ce11ee898714e93)
sa_sigaction字段是一个替代的信号处理程序,当在sigaction结构中使用了SA_SIGINFO标志时,使用该信号处理程序。
通常,按下列方式调用信号处理程序:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/9e12f1d3e499fc949c886e7c9e0484f9)
void handler(int signo);
但是,如果设置了SA_SIGINFO标志,那么按照下列方式调用信号处理程序:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/9e12f1d3e499fc949c886e7c9e0484f9)
void handler(int signo, siginfo_t *info, void *context);
siginfo_t结构包含了信号产生原因的有关信息,该结构的大致样式如下:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/9e12f1d3e499fc949c886e7c9e0484f9)
struct siginfo{
int sig_signo; //信号
int sig_errno; //如果不是0,就是errno.h中的errno值
int sig_code; //附加信息(取决于信号)
pid_t si_pid; //发送信号的进程ID
uid_t sig_uid; //发送信号的进程真实用户ID
void *si_addr; //产生错误的地址
int si_status; //退出值或者信号值
long si_band; //SIGPOLL的band号
//可能还会有其他的值。
}
实践:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/9e12f1d3e499fc949c886e7c9e0484f9)
#include <stdio.h>
#include <signal.h>
static void sighandle(int signo){
printf("catch signo:%d\n",signo);
}
int main(void){
struct sigaction act;
act.sa_handler = sighandle;
sigemptyset(&act.sa_mask);
act.sa_flags = 0;
if(sigaction(SIGQUIT,&act,NULL) <0){
perror("sigaction");
return -1;
}
while(1){
pause();
}
return 0;
}
运行结果:
yan@yan-vm:~/apue$ ./a.out
^\catch signo:3
^\catch signo:3
^\catch signo:3
^\catch signo:3
^C
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
#include<signal.h>
int sigaction(int signo, const struct sigaction *restrict act, struct sigaction *restrict oact);
//若成功则返回0,出错则返回-1.
参数signo是要检测或修改其具体动作的信号编号。
若act指针非空,则要修改其动作;如果oact指针非空,则系统经由oact指针返回该信号的上一个动作,此函数使用如下结构:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
struct sigaction{
void (*sa_handler)(int); //信号捕捉函数的地址或者SIG_IGN,或者SIG_DFL
sigset_t sa_mask; //在调用信号捕捉函数之前要屏蔽的信号,当从信号步骤函数返回时,将进程信号屏蔽字复原。
//操作系统建立的新信号屏蔽字包含正在被递送的信号。
int sa_flags; //信号选项
void (*sa_sigaction)(int, siginfo_t*, void*); //替代信号处理函数地址
}
act结构的sa_flags字段指定对信号处理的各个选项。
sa_sigaction字段是一个替代的信号处理程序,当在sigaction结构中使用了SA_SIGINFO标志时,使用该信号处理程序。
通常,按下列方式调用信号处理程序:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
void handler(int signo);
但是,如果设置了SA_SIGINFO标志,那么按照下列方式调用信号处理程序:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
void handler(int signo, siginfo_t *info, void *context);
siginfo_t结构包含了信号产生原因的有关信息,该结构的大致样式如下:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
struct siginfo{
int sig_signo; //信号
int sig_errno; //如果不是0,就是errno.h中的errno值
int sig_code; //附加信息(取决于信号)
pid_t si_pid; //发送信号的进程ID
uid_t sig_uid; //发送信号的进程真实用户ID
void *si_addr; //产生错误的地址
int si_status; //退出值或者信号值
long si_band; //SIGPOLL的band号
//可能还会有其他的值。
}
实践:
[cpp] view
plain copy
![](https://oscdn.geek-share.com/Uploads/Images/Content/201611/a7c8e286f463007e2a900848b93dd72c.png)
#include <stdio.h>
#include <signal.h>
static void sighandle(int signo){
printf("catch signo:%d\n",signo);
}
int main(void){
struct sigaction act;
act.sa_handler = sighandle;
sigemptyset(&act.sa_mask);
act.sa_flags = 0;
if(sigaction(SIGQUIT,&act,NULL) <0){
perror("sigaction");
return -1;
}
while(1){
pause();
}
return 0;
}
运行结果:
yan@yan-vm:~/apue$ ./a.out
^\catch signo:3
^\catch signo:3
^\catch signo:3
^\catch signo:3
^C
相关文章推荐
- 本地代码上传 -&gt; Github
- Git——新手入门与上传项目到远程仓库GitHub(转)
- java读取properties文件
- HDU——1397Goldbach's Conjecture(二分查找+素数打表)
- 框架 day27 Struts2 入门(概述,基本xml配置,动态方法调用,Action类,ServletAPI访问,结果集)
- Eclipse中安装部署maven插件
- Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)
- python对于中文编码处理的几种方式
- 斐波那契数列
- typedef struct 用法详解和用法小结 及 在C和C++中的区别
- 《编程之美》- 2.4 - 1的个数
- Restful形式接口文档生成之Swagger与SpringMVC整合手记
- OpenGL编程指南第九章:纹理映射
- java变量初始化
- OpenGL编程指南第五章:光照
- C++ STL--stack/queue 的使用方法
- java中thread的start()和run()的区别
- Python opencv图像镜像翻转
- OpenGL编程指南第四章:颜色
- Java第六次作业