我有一个创建并返回节点的函数,我计划将其添加到哈希表中:
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;
}
但我得到一个警告,告诉我返回的是一个局部变量的地址。
有没有一种方法可以在不首先将大量结构赋给变量的情况下将它们赋给表?
最佳答案
当new
函数定义遇到CreateNode
标点符号(即结束)时,将返回一个本地对象}
,该对象的生存期将结束。从外部读取此类对象是未定义的行为。
相反,将CreateNode
定义为:
HashTableNode* CreateNode(char* url)
{
HashTableNode *new = malloc(sizeof(*new));
// new->url...
return new;
}
这也解决了
AddToHashTable
调用的问题,因为您已经有一个HashTableNode*
类型的指针:AddToHashTable(&lookup_table, CreateNode(result));
建议您经常检查
malloc
函数的结果,因为它有一天可能会失败。关于c - 向数据结构中添加许多结构(需要一元'&'操作数的左值),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/31777280/