这是我所拥有的:
struct test_date {
time_t t;
pid_t pid;
};
int main(int argc, char *argv[]) {
dates = malloc(CHILDREN_LIMIT * sizeof(struct test_date*)); // an array declared static of type struct test_date
//... later
struct test_date *td = &dates[children]; //children is a counter
if (fork() == 0) { // in a child process
td->pid = getpid();
time(&(td->t));
//now, if I print the date, I get a strange result. look bellow for get_time function.
printf("%s\n", get_time(&td->t));
//...
}
//...
exit(0);
}
char *get_time(time_t *t) {
struct tm *bt = malloc(sizeof(struct tm*));
char *strt = malloc(DATE_SIZE * sizeof(char *));
localtime_r(t, bt);
strftime(strt, 100, "%Y-%m-%d %T", bt);
return strt;
}
此代码的输出:
例如。应该是:2013-07-16 09:21:28
但它是:2013-858861619-16 09:21:28
更重要的是,如果我printf
稍后调用相同的函数,在从子进程调用的某些函数中,我会得到更糟糕的结果。某个日期到 1974 年。
谁能告诉我我的错误在哪里?我想这应该是我将time_t
变量作为指针传递的地方,但我不明白为什么会出现这种行为。有人可以详细介绍这个话题吗?