我是c的新手,我正在实现DHT。为此,我必须将节点ID存储在一个列表中。
节点ID为<2^160个整数(因此我使用GMP(,但我在这里将123设置为ID以保持示例的整洁。
我可以很好地设置节点的ID,并且我还可以用mpz_out_str
验证它。当我用g_slist_foreach
迭代它并打印ID时,它会输出一个巨大的数字,这是完全无关的。
我怀疑这与从gpointer
到Node
的强制转换有关,或者我可能存储不正确(指针非常新(
代码:
#include <glib.h>
#include <gmp.h>
#include <stdio.h>
typedef struct {
mpz_t *node_id;
} Node;
void print_iterator(gpointer item, gpointer prefix) {
// Also, since the item is of type gpointer,
// It has to be casted back to Node.
Node *node = (Node *)item;
// outputs a HUGE, completely random number.
mpz_out_str(stdout, 10, node->node_id);
printf("n");
};
GSList *add_node(GSList *nodes) {
Node *node = malloc(sizeof(Node));
mpz_t id;
mpz_init(id);
char *f = "123";
mpz_set_str(id, f, 10);
node->node_id = &id;
// prints correct value
mpz_out_str(stdout, 10, node->node_id);
nodes = g_slist_append(nodes, node);
return nodes;
}
int main(int argc, char const *argv[]) {
GSList *nodes = NULL;
nodes = add_node(nodes);
g_slist_foreach(nodes, print_iterator, "‑‑>");
return 0;
}
相关链接:
https://developer.gnome.org/glib/stable/glib-Singly-Linked-Lists.html
https://gmplib.org/manual/
使用node->node_id = &id;
,node_id指向一个局部变量。当add_node
返回时,id
将被销毁,并且您的指针处于悬空状态。取消引用会导致"未定义的行为"。
一个简单的解决方案是将id存储在Node
中,而不是存储指向它的指针
typedef struct {
mpz_t node_id;
} Node;