Unix网络编程 中提到,可以使用alarm + signal 机制产生信号,从而使程序从阻塞的函数调用中跳出,例子如下:
服务进程使用阻塞的监听套接字进入监听,设置3s的alarm,确保3s内无客户端连接,看服务进程是否能在alarm触发后跳出accept阻塞;
server.c
...
void alarm_hander(int signo)
{
printf("alarm...\n");
}
void main()
{
...
listen(listenfd,queuelen);
//alarm test
void *oldfun;
oldfun = signal(SIGALRM,alarm_hander);
alarm(3);
printf("before accept\n");
accept(listenfd,NULL,0);
printf("after accept\n");
signal(SIGALRM,oldfun);
....
}
运行结果:
root@cloud2:~/slp/NetWrokProgram/server# ./a.out
before accept
alarm...
可以看出,程序在处理alarm信号后(alarm_hander打印的“alarm...”信息)继续进入accept阻塞了,此间客户端向该服务端口发出一个连接请求,紧接着服务端打印了如下信息:
after accept
root@cloud2:~/slp/NetWrokProgram/server#
实践证明,Linux在处理完信号中断后,还会进入原有的阻塞代码中,而不是执行阻塞代码的下一条。