Chinaunix

标题: apue中10.6节例子,signal(SIGALRM, my_alarm)执行不了,为啥? [打印本页]

作者: dothingsbyjava    时间: 2011-08-08 23:33
标题: apue中10.6节例子,signal(SIGALRM, my_alarm)执行不了,为啥?
本人在CentOs5.3中试过,就是一直死循环,郁闷。

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <unistd.h>
  5. #include <signal.h>
  6. #include <pwd.h>
  7. #include <error.h>

  8. static void my_alarm(int signo)
  9. {
  10.     struct passwd *rootptr;

  11.     printf("in signal handler\n");
  12.     if ((rootptr = getpwnam("root")) == NULL)
  13.     {
  14.         printf("getpwnam(root) error");
  15.     }
  16.     alarm(1);
  17.     return;
  18. }

  19. int main(void)
  20. {
  21.    struct passwd *ptr;

  22.    signal(SIGALRM, my_alarm);

  23.    while(1)
  24.    {
  25.        if ((ptr = getpwnam("foxhunt")) == NULL)
  26.        {
  27.            printf("getpwnam error\n");
  28.        }

  29.        if (strcmp(ptr->pw_name, "foxhunt") != 0)
  30.        {
  31.            printf("return value corrupted!, pw_name=%s\n", ptr->pw_name);
  32.        }
  33.    }

  34.     return 0;
  35. }

复制代码

作者: dothingsbyjava    时间: 2011-08-10 19:56
{:3_199:}没人理我。。。
作者: whaaat    时间: 2011-08-11 09:59
不需要调用alarm()么?
作者: hailongxl    时间: 2011-08-11 10:09
while(1)循环中加入usleep(1000*1000);
作者: jiayanfu    时间: 2011-08-11 10:40
额。。。你的alarm在主函数为什么不调用呢。。。。是不是在“signal(SIGALRM, my_alarm);“之后应该“alarm(1)”呢。。。。。。楼主。。。。。是不是呢。。。{:2_167:}
作者: jiayanfu    时间: 2011-08-11 10:56
还有你的while里边是不是应该睡一会儿呢。。。我怕cpu吃不消啊{:2_166:}。。。 我帮你测试过了,这样修改完了就可以正常的发出SIGALRM了
作者: dothingsbyjava    时间: 2011-08-11 12:48
谢谢楼上各位的回答,确实漏写了alarm(),谢谢了,我回去再试试。{:3_189:}




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2