APUE 第三版 程序10-10 带时间限制调用 read (alarm解低速系统调用阻塞)

如有错误,欢迎批评指正,本人也是才学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 被中断,然后在信号处理程序返回时,重启该系统调用)

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值