最近更新:
1,父进程fork一个子进程,当向父进程发送一个SIGINT或其它信号时,子进程是否会接受到该信号?
2,父进程调用system执行一个程序时,向父进程发送一个信号时,system运行中的程序是否能够接受到该信号?
3,当父进程正常执行完毕后,会通知子进程吗?
是我自己的笔记,乱七八糟的。
语法:如果参数为const型,仅表示该参数在此函数的实现中不能被修改,不代表传入的参数类型一定是const型
int sigsuspend(const sigset_t *sigmask);
代码片段:
sigset_t zeromask;
sigemptyset(&zeromask);
sigsuspend(&zeromask);
signal继承问题:子进程会继承父进程的signal mask 测试地址:http://blog.chinaunix.net/uid-29100821-id-4018170.html
理论说明:http://blog.csdn.net/lihuibo128/article/details/8556669
unix的读写函数:open,write,read
说明:http://www.cnblogs.com/Pierre-de-Ronsard/archive/2012/07/09/2582417.html
实验1:信号屏蔽字
1,构造一个进程:进程设置对某个信号的处理函数,模拟该信号处理,检验是否如预期
2,构造一个进程:进程设置对某个信号的处理函数,用sigprocmask设置,该进程对这一信号屏蔽,模拟该信号,检查是否如预期,使用其它信号,检查是否如预期
就能够知道sigprocmask函数的功能。
sigpromask:用来设置进程的信号屏蔽,哪些信号不被进程所响应,及时设置了signal的信号handler
实验1扩展知识
与信号集合相关的一组操作是:
int main()
{
sigset_t sigset, oldmask; signal(SIGUSR1, proc_usr1); sigprocmask(, NULL, &oldmask); sigaddset(&sigset, SIGUSR1);
sigprocmask(SIG_BLOCK, &sigset, NULL); pr_mask("Block SIGUSR1"); sleep();
sigprocmask(SIG_SETMASK, &oldmask, NULL);//设置新的屏蔽字为oldmask
//sigprocmask(SIG_UNBLOCK, &sigset, NULL);//清除设置的屏蔽字
pr_mask("Unblock SIGUSR1"); sleep(); return ;
}
运行,产生一次SIGUSR1信号
输出:
Block SIGUSR1:SIGUSR1 proc_usr1
Unblock SIGUSR1: