我有一个创建并返回节点的函数,我打算将其添加到哈希表中:
HashTableNode CreateNode(char* url){
HashTableNode new;
new.url = malloc(sizeof(char) * (strlen(url) + 1));
strcpy(new.url, url);
return new;
}
我正在尝试将许多这些节点添加到哈希表中,但我遇到了一个问题:
AddToHashTable(&lookup_table, &CreateNode(result));
给了我一个错误(左值作为一元'&'操作数)。我相信这是因为我返回的结构在内存中没有关联的地址。为了测试一些功能,我可以手动分配几个节点并将它们添加到哈希表中,但显然这个解决方案不能很好地扩展。
我已尝试在我的CreateNode函数中返回指向节点的指针:
HashTableNode* CreateNode(char* url)
{
HashTableNode new;
new.url = malloc(sizeof(char) * (strlen(url) + 1));
strcpy(new.url, url);
return &new;
}
但我得到一个警告,告诉我我正在返回一个局部变量的地址。
有没有办法在不先将变量分配给变量的情况下为表分配大量结构?
答案 0 :(得分:1)
当 new
函数定义遇到CreateNode
标点符号(即结束)时,您将返回本地对象}
,其中生存期结束。从外部读取此类对象是未定义的行为。
相反,将CreateNode
定义为:
HashTableNode* CreateNode(char* url)
{
HashTableNode *new = malloc(sizeof(*new));
// new->url...
return new;
}
这也可以通过AddToHashTable
调用解决您的问题,因为您已经有HashTableNode*
类型的指针:
AddToHashTable(&lookup_table, CreateNode(result));
建议练习始终检查malloc
函数的结果,因为它有一天可能会失败。