日期:2014-05-16  浏览次数:20834 次

Linux 2.6 Alarm信号中断遇上函数阻塞

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