我对链表的c代码完全感到困惑。该代码在Visual Studio中正常工作,但在Linux中则不然。代码如下
typedef struct map
{
char key[50];
char value[50];
struct map* next;
} map_t;
void AddEntry( map_t** head, char* key, char* value )
{
map_t* newEntry = (map_t*)malloc(sizeof(map_t) );
strcmp( newEntry->key, key);
strcmp( newEntry->value, value);
newEntry->next = NULL;
if ( *head == NULL )
{
*head = newEntry;
}
else
{
map_t** currentEntry = head;
while ( (*currentEntry)->next != NULL )
{
*currentEntry = (*currentEntry)->next;
}
(*currentEntry)->next = newEntry;
}
}
这是我的电话:
map_t* localListHead = NULL;
AddEntry( &localListHead, "??", "Test" );
有人看到我没有看到的东西吗?
我可能错了,但似乎您的 else 块中的代码有问题。声明分配给head
的map_t** currentEntry
,然后写入其中。你为什么要这样做?
据我所知,你真正想要的是一个map_t* currentEntry = *head
.