3

这是来自 gdb:

22      database->size = size;
(gdb) n
23      return database;
(gdb) p size
$6 = 1401
(gdb) p database->size
$7 = 3086862424
(gdb) p &size
$8 = (unsigned int *) 0xbffff050
(gdb) p &database->size
$9 = (unsigned int *) 0xb7fc6ff8

这是来自代码:

typedef struct _DATABASE {
    RESULT* res;
    unsigned int size;
} DATABASE;

....
....

DATABASE* alloc_database(unsigned int size, DATABASE* database)
{
    database = (DATABASE*) malloc (sizeof(DATABASE));
    if (!database) return NULL;
    database->res = (RESULT*) malloc (sizeof(RESULT) * size);
    if (!database->res) {
        free_database(database);
        return NULL;
    }
    memset(database->res, 0, sizeof(RESULT) * size);
    database->size = size;
    return database;
}

您可以看到 database->size 和 size 都来自 (unsigned int) 类型,在代码和 gdb 中,但由于某种原因,赋值后的值不同。

有谁知道这是什么原因?

4

1 回答 1

1

数据库是函数 alloc_database 的本地数据库。您将 malloc 的结果分配给它,但此分配是函数的本地分配。返回后,数据库返回到调用函数时的值。请注意,在 gdb 中,您在返回后检查 database->size 的值。因此,您在数据库的值在函数之外的范围内检查它。

你有两个选择:

  1. 将函数更改为仅接收 size 参数,分配给本地并返回它。然后您可以分配返回值并在gdb中检查它:

  2. 如果要在数据库参数中返回结果,则需要将指针传递给数据库指针。

这是选项 2 的代码:

DATABASE* alloc_database(unsigned int size, DATABASE** database)
{
    *database = (DATABASE*) malloc (sizeof(DATABASE));
    if (! *database) return NULL;
    (*database)->res = (RESULT*) malloc (sizeof(RESULT) * size);
    if (!(*database)->res) {
        free_database((database);
        *database = NULL;
        return NULL;
    }
    memset((*database)->res, 0, sizeof(RESULT) * size);
    (*database)->size = size;
    return (*database);
}

PS אהבה לא באה בחינם...

于 2012-12-27T21:47:29.323 回答