0

我在我的内存结构下的 GLib 哈希表中添加了几个键值对。键是从 malloc 返回的 (char *) 指针。该值是分配的 malloc 大小。

void addstomemstruct(struct memory *mem, char *key_address, size_t sz) {
    g_hash_table_insert(mem->singleton, key_address, &sz);
    printf("** retrieving size: %Zu add=%p\n",(*(size_t*) g_hash_table_lookup(mem->singleton, key_address)), key_address);
}

后来我根据key去取value的时候,返回的size(value)总是10,这是我最后加到hash表中的值

size_t get_blocksize(GHashTable *hashtable, char *key_address, size_t *result_flag)
{   size_t *sz_ptr = (size_t *) g_hash_table_lookup(hashtable, key_address);
    ...

char *logmsg;asprintf(&logmsg,"In get_blocksize: *sz_ptr=%Zu\n",*sz_ptr);
    log_msg(logmsg);

printf("** retrieving size: %Zu add=%p\n",(*(size_t*) g_hash_table_lookup(hashtable, key_address)), key_address);
...
}

打印出:

preparing to add pointer: 0x9b52f10
** adding size: 1
** retrieving size: 1 add=0x9b52f10
preparing to add pointer: 0x9b52f48
** adding size: 2
** retrieving size: 2 add=0x9b52f48
preparing to add pointer: 0x9b52f58
** adding size: 3
...
preparing to add pointer: 0x9b52fc8
** adding size: 10
** retrieving size: 10 add=0x9b52fc8

然后当我尝试检索第一个值时:

In get_blocksize: *sz_ptr=10
** retrieving size: 10 add=0x9b52f10
Freed address 0x9b52f10.  Size: 10. mem->stats->active_count=9, mem->stats->active_size=45.
4

1 回答 1

3

您将指向自动存储持续时间变量(函数参数)的指针作为哈希表值传递。当它超出范围时,访问它是一种未定义的行为。

您可以:

  • sz为with malloc/分配存储,并在创建哈希表时gnew注册一个适当的。value_destroy_func
  • 利用size_tvalue 适合指针并将其强制转换为gpointer. 从技术上讲,这是一个 UB,但应该适用于大多数平台。除非小对象分配被确定为瓶颈,否则可能不应该这样做。
于 2012-09-26T05:52:06.530 回答