gpt4 book ai didi

c - Glib 哈希表 - 键不存在

转载 作者:行者123 更新时间:2023-11-30 17:36:39 24 4
gpt4 key购买 nike

我正在开发一个程序,它使用 Glib 的哈希表。当程序启动时,它读取一个文件,并根据这些数据填充哈希表。当程序运行时,用户提供他们的数据,代码检查 key 是否存在 - 如果是,则更新值,如果不存在,则插入新 key 。

这是示例:

    // fill hash with data's
datastore = g_hash_table_new(g_str_hash, g_str_equal);
while (fgets(inputbuffer, 90, fp) != NULL) {
parse_utypeline(inputbuffer, udatakey, &udataidx); // parse line, store fields in udatakey and udataidx
utype_inc(udatakey, udataidx); // push to hash
total++;
}


// another part of code, find value of key
nrofutype = utype_get(utypereclist.udatakey, udatainx);

// implemented functions
int utype_inc(char udatakey[15], int udata) {

t_utype_rec_udatas *utype_rec_udatas;
int i;
gboolean gb;
GList * hkeys = NULL;
int gi;

syslog(LOG_DEBUG, "utype store: %p", datastore);
gb = g_hash_table_contains(datastore, udatakey);

if (gb == 0) {
utype_rec_udatas = g_malloc0(sizeof *utype_rec_udatas);
for(i=0; i<10; i++) {
/*
* every item has derived like this:
* typedef unsigned char t_utype_rec_udatas[10];
* t_utype_rec_udatas *utype_rec_udatas;
*/
(*utype_rec_udatas)[i] = 0;
}
g_hash_table_insert(datastore, udatakey, utype_rec_udatas);
}
else {
utype_rec_udatas = g_hash_table_lookup(datastore, udatakey);
}
(*utype_rec_udatas)[udata]++;

gb = g_hash_table_contains(datastore, udatakey);
if (gb == 0) {
return -1;
}
else {
utype_rec_udatas = g_hash_table_lookup(datastore, udatakey);
return (*utype_rec_udatas)[udata];
}

}

int utype_get(char udatakey[15], int udata) {
t_utype_rec_udatas *utype_rec_udatas;
gboolean gb;

if (datastore == NULL) {
syslog(LOG_DEBUG, "store doesn't exists");
return -1;
}

gb = g_hash_table_contains(datastore, udatakey);
if (gb == 0) {
return -1;
}
else {
utype_rec_udatas = g_hash_table_lookup(datastore, udatakey);
return (*utype_rec_udatas)[udata];
}
}

问题是,如果代码在后面的部分中调用 utype_get(),则该 key 不存在(当然存在)。如果我放置系统日志行,并 try catch 一些数据,我会看到哈希表地址每次都是相同的。如果 utype_inc() 函数记录了 udatakey,它在系统日志中似乎是正确的(我已记录来自 g_hash_table_get_keys(datastore); 的数据)。但是,如果调用 utype_get(),g_hash_table_get_keys(datastore); 会提供一些非常重要的信息...来自同一存储!这是系统日志行:

Mar 23 18:13:09 basil myprog: udata store: 0x2371400
Mar 23 18:13:09 basil myprog: new udatakey: 'ABCD', udataidx: 0
Mar 23 18:13:09 basil myprog: store value: 1
Mar 23 18:13:09 basil myprog: 0. key: 'ABCD'
Mar 23 18:13:09 basil myprog: size of hash: 1

Mar 23 18:13:13 basil myprog: udata_get - udatakey: '', udataidx: 0
Mar 23 18:13:13 basil myprog: udata_get - size of hash: 1
Mar 23 18:13:13 basil myprog: udata_get - 0. key: '#020#001'
Mar 23 18:13:13 basil myprog: udata_get - udatakey doesn't exists in store: 0x2371400

我不知道,#020#001 是什么(我知道,这可能是一个空格,还有一个 0x01),但为什么呢?

欢迎任何帮助,

谢谢:

一个。

最佳答案

解决方案是:

char datakeys[BIGNR][15];

// implemented functions
int utype_inc(char udatakey[15], int udata) {
...
gb = g_hash_table_contains(datastore, udatakey);

if (gb == 0) {
utype_rec_udatas = g_malloc0(sizeof *utype_rec_udatas);
for(i=0; i<10; i++) {
/*
* every item has derived like this:
* typedef unsigned char t_utype_rec_udatas[10];
* t_utype_rec_udatas *utype_rec_udatas;
*/
(*utype_rec_udatas)[i] = 0;
}
gi = g_hash_table_size(datastore_store);
strncpy(datakeys[gi], udatakey, strlen(udatakey));
g_hash_table_insert(datastore, datakeys[gi], utype_rec_udatas);
}
...
...

感谢您的帮助,

一个。

关于c - Glib 哈希表 - 键不存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22594306/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com