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在处理完信号中断后,还会进入原有的阻塞代码中,而不是执行阻塞代码的下一条。