1

这是我所拥有的:

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变量作为指针传递的地方,但我不明白为什么会出现这种行为。有人可以详细介绍这个话题吗?

4

2 回答 2

2
struct tm *bt = malloc(sizeof(struct tm*));
char *strt = malloc(DATE_SIZE * sizeof(char *));

应该:

struct tm *bt = malloc(sizeof(struct tm));
char *strt = malloc(DATE_SIZE * sizeof(char));

main

dates = malloc(CHILDREN_LIMIT * sizeof(struct test_date*)); 

应该

dates = malloc(CHILDREN_LIMIT * sizeof(struct test_date)); 

我想你可能对 的用法有误解malloc,请查看手册,并使用这种更安全的形式,详见此处

struct tm* bt = malloc(sizeof(*bt));
于 2013-07-16T06:54:22.703 回答
1

您分配的结构tm太小。

它应该是

struct tm *bt = malloc(sizeof(struct tm));

strftime将一些数据写入不是由 malloc 分配的内存,这可能是另一个分配的内存块的一部分,也许是strt的一部分。这可能会导致奇怪的值。这同样适用于dates数组的分配。

于 2013-07-16T06:54:45.950 回答