我有代码使用函数"time"和"time.h"中的其他函数,并且"time"每次"时间"都返回NULL(哈哈虽然不好笑,但这在"时间"上很昂贵,我可以将注意力集中在这些上)这样被重新执行。奇怪的是,这才从昨天开始。以前在类似但缺乏(我一直在添加)代码中使用相同函数证明是可以的。以下是 C89 代码:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define EXIT_SUCCESS 0
#define EXIT_FAILURE 1
typedef struct tm tm;
int logf(char input_string[])
{
time_t* current_time_since_epoch;
time(current_time_since_epoch);
if (current_time_since_epoch == NULL)
{
printf("'time' returned NULL.n");
return EXIT_FAILURE;
}
tm* current_time_calandar_time = localtime(current_time_since_epoch);
if (current_time_calandar_time == NULL)
{
printf("'localtime' returned NULL.n");
return EXIT_FAILURE;
}
char current_time_textual_representation[20];
strftime(current_time_textual_representation, 20, "%d-%m-%Y %H:%M:%S", current_time_calandar_time);
printf("%sn", current_time_textual_representation);
printf("%sn", input_string);
return EXIT_SUCCESS;
}
int main(void)
{
int check_logf = logf("Hello.");
if (check_logf == 0) exit(EXIT_SUCCESS);
else
{
printf("'logf' returned EXIT_FAILURE.n");
exit(EXIT_FAILURE);
}
}
当您将time_t
的地址传递给time()
时,它会将结果存储在该地址。由于您没有分配任何内存来存储结果(您所做的只是声明一个未初始化的指针),因此您得到了未定义的行为。 只需将NULL
传递给time
,它就会返回值。
time_t current_time_since_epoch = time(NULL);
结果作为参数提供,则需要为 time()
函数分配内存来存储结果。要么在堆栈上声明变量,要么调用 malloc()
。如果将NULL
作为参数,也可以检索返回值。
time_t current_time_since_epoch;
time(¤t_time_since_epoch);
// or
current_time_since_epoch = time(NULL);
// or
time_t* timePtr = (time_t*) malloc(sizeof(time_t));
time(timePtr);
// ...
free(timePtr);
有关功能time()
原型的更多信息,请单击此处