如有错误,欢迎批评指正,本人也是才学APUE的菜鸟
程序代码:
#include "apue.h"
static void sig_alrm(int);
int main(void) {
int n;
char line[MAXLINE];
if(signal(SIGALRM, sig_alrm) == SIG_ERR)
err_sys("signal(SIGALRM) error");
alarm(10);
if((n = read(STDIN_FILENO, line, MAXLINE)) < 0)
err_sys("read error");
alarm(0); // 如果有以前注册的尚未超时的闹钟时间,而且本次调用的
// seconds 是 0,则取消以前的闹钟时间,并将余留值作为返回值。
write(STDOUT_FILENO, line, n);
exit(0);
}
static void sig_alrm(int signo) {
}
终端运行的结果:
hjm@hjm-Inspiron:~/InterviewPreparation/apue/Examples/10-10$ gcc -o 10-10 10-10.c -lapue
hjm@hjm-Inspiron:~/InterviewPreparation/apue/Examples/10-10$ ./10-10
read error: Interrupted system call
看了代码一遍又一遍,一直不明白为什么可以解阻塞。
alarm 函数在到时间时发送一个 SIGALRM 信号,况且代码已经捕获了该信号,而不是采用默认动作让系统终止调用此 alarm 的进程,该进程是如何结束的?
【】幸好在网上找到了解释的博客。
在 10.5 节中提到,如果进程在执行一个低速系统调用而阻塞期间捕捉到一个信号,则该系统调用就被中断不再执行。该系统调用返回出错,并将 errno 设置为 EINTR (Interrupt system call)。
关于低速系统调用见 10.5 节。
!!注意:
同时,书上还指出,如果系统调用是自启动的,则该时间限制是不起作用的。当从 SIGALRM 信号处理程序返回时,read 并不被中断。(书上是这样说的,但根据 10.5 节,应该是 read 被中断,然后在信号处理程序返回时,重启该系统调用)