5

我对 PHP 和使用当前时间的 C 脚本有一个奇怪的问题。我的程序有点复杂,但问题仅限于此:

我有这个 C 代码,它打印 1 分钟前的日期、当前日期和 1 分钟后的日期:

#include <time.h>
#include <stdio.h>

int main(int argc, char **argv){
  char date[9];
  time_t rawtime;
  struct tm * ptm;
  int i;

  time(&rawtime);
  ptm = gmtime(&rawtime);
  ptm->tm_min--;

  for(i = 0; i < 3; i++){
    rawtime = mktime(ptm);
    ptm = gmtime(&rawtime);
    snprintf(date, 9, "%d %d %d", ptm->tm_mday, ptm->tm_hour, ptm->tm_min);
    printf("%s\n", date);

    ptm->tm_min++;
  }
  return 0;
}

当我在 shell 中运行它时,我得到了正确的结果(打印格式是月份中的日期、小时、分钟):

$ ./test
17 20 7
17 20 8
17 20 9

但是,当我通过 PHP 执行它时,我得到了奇怪的结果。这是PHP代码:

<?php
exec("path_to_exec/test", $output);
echo "$output[0]<br/>";
echo "$output[1]<br/>";
echo "$output[2]<br/>";
?>

这是输出:

17 20 7
17 17 8
17 14 9

时间显然是错误的。任何人都知道可能导致这种情况的原因吗?

4

1 回答 1

3

问题在于 C 代码,而不是 PHP 代码:

当你这样做时:

rawtime = mktime(ptm);

ptm指针由函数mktime修改。因此,如果您这样做:

rawtime = mktime(ptm);
ptm = gmtime(&rawtime);

您实际上是在操纵指针两次,因此结果很奇怪。

而不是上面的,只是做:

mktime(ptm);
snprintf(...);

你会得到预期的结果。因此,完整的for循环代码将是:

mktime(ptm);
snprintf(date, 9, "%d %d %d", ptm->tm_mday, ptm->tm_hour, ptm->tm_min);
printf("%s\n", date);
ptm->tm_min++;
于 2011-11-17T20:56:11.367 回答