alarm()函数不会在正确的时间关闭

时间:2013-11-06 23:14:07

标签: c printing signals printf alarm

我有一个程序应该从命令行接受3个不同的参数。第三个参数是传递给警报功能的唯一参数。例如,如果我的程序被称为BuzzOff,那么它就是这样的:

$ BuzzOff 10 99999 1

第三个参数是1,因此1将被传递到警报功能。我的程序应该每arg3秒打印出变量total的值。在这种情况下每1秒。但是,当我尝试使用1作为我的第三个参数时,警报需要的时间超过1秒。大约需要14秒。无论我使用什么作为我的arg3,它似乎以相同的速率打印。我是否正确实施了闹钟功能?

这是我的代码:

#include<stdio.h>
#include<signal.h>
#include<stdlib.h>

double arg1, arg2, arg3;
double total = 0;
int debug = 0;

void sigusr1_handler(int signo)
{
    if (signo == SIGUSR1)
      printf("total: %f\n", total);
}
void sigusr2_handler(int signo)
{
    if (signo == SIGUSR2)
      debug = ((debug == 1) ? 0 : 1);
}
void sigint_handler(int signo)
{
  if (signo == SIGINT)
    {
      printf("total: %f\n", total);
      exit(0);
    }
}
void sigalrm_handler(int signo)
{
  if (signo == SIGALRM)
    {
      printf("total: %f\n", total);
      signal(SIGALRM, sigalrm_handler);
      alarm(arg3);
    }
}

int main(int argc, char *argv[])
{
    if( argc!=4 ) {
        printf("need three arguments\n"); return(1);
    }
    arg1 = (double) atoi(argv[1]);
    arg2 = (double) atoi(argv[2]);
    arg3 = (double) atoi(argv[3]);

    double count;

    signal(SIGUSR1, sigusr1_handler);
    signal(SIGUSR2, sigusr2_handler);
    raise(SIGUSR2);
    if (debug == 1)
      {
    signal(SIGUSR1, SIG_IGN);
    signal(SIGALRM, sigalrm_handler);
    alarm(arg3);
      }
    else if (debug == 0)
      {
    signal(SIGUSR1, sigusr1_handler);
    signal(SIGINT, sigint_handler);
      }
    for (count = 0; count < arg2; count += 0.001)
      {
    total += count*arg1;
      }
    return 0;

}

1 个答案:

答案 0 :(得分:2)

您将输入转换为double,但alarm()函数需要unsigned int。不知道1.0的下半部分(上半部分)的位模式是什么,但如果它出现为14,我不会感到惊讶。

编译器是否不抱怨将double arg3传递给alarm()