0

我正在尝试将新节点添加到具有 char* 字段(单词)的结构中

listT的定义:

enum boolean {false, true};
struct list {
    enum boolean sorted;
    union{
        int words;
        char *word;
    };
    struct list* next;
    struct list* previous;
};
typedef struct list listT;

add_word_node 函数被 main 调用为:add_word_node(read_word, list_head) whereread_word由用户使用 scanf 给出。Word 作为字符串传递,但在 strncpy 之后没有终止字节。

>Debugger:
     add_word_node (word=0xbffff0fa "ally", head=0x804c038) at prog.c    
>Debugger:
     (gdb) p newnode->word


     $2 = 0x804c068 "allyP\224\373\267\377\377\377\377" 




 listT *add_word_node(char word[], listT *head) {
    listT *newnode;
    listT *curr = NULL;//sorted
    //listT *prev;//sorted

    newnode = malloc(sizeof(listT)); /* allocate new node and check */
    newnode->word = malloc(sizeof(char)* WORDLEN);
    strncpy(newnode->word, word, strlen(word));
    //newnode->word = strndup(word, strlen(word));


    if (newnode == NULL) {
        return (NULL);
    }

    if (head->sorted == false){ //eisagwgh sto telos ths listas
        newnode->next = head;
        head->previous->next = newnode;
        newnode->previous = head->previous;
        head->previous = newnode;
    }else {
        if(head->next == head){
            newnode->next = head;
            newnode->previous = head;
            head->next = newnode;
            head->previous = newnode;

        }else{
            for (curr = head->next; curr->next != NULL; curr = curr->next){//for( curr = head->next; ;){
                if(curr == NULL) break;
                if(strncmp(curr->word,newnode->word,strlen(word)) > 0) break;
                //else curr= curr->next;
            }
            if(strncmp(curr->word,newnode->word,strlen(word))== 0){
                return(curr);
            }
            newnode->next = curr;
            newnode->previous = curr->previous;
            newnode->previous->next = newnode;
            newnode->next->previous = newnode;
        }
    }

    return (newnode);

}

我已经阅读了有关此问题的其他一些主题,并且我将函数更改为使用 word[] 而不是 char* 但它仍然不起作用。如果您需要更多信息,请告诉我。另外,当我使用 strndup 时,它有时可以正常工作。

4

2 回答 2

0

正如你所说你有一个char *word那么这个指针应该被分配内存

newnode->word = malloc(sizeof(char) * (WORDLEN+1)); /* Please access the structure elements accordingly */

在向指针写入内容之前,应为指针分配内存。

于 2014-12-27T18:20:02.317 回答
0

稍微扩展@Gopi的答案:

你的陈述

newnode = (listT *) malloc(sizeof(listT) + WORDLEN);

为指针分配内存newnode。这意味着,例如,如果WORDLEN与 相同sizeof(listT),那么您将为 的两个listT元素分配内存newnode。这类似于,比如说,char *ptr = malloc(2);它将charptr.

TL;DR:此WORDLEN内存不会分配给newnode->word,而是分配给 ,仅此而已newnode。要解决您的问题,您必须newnode->word单独分配内存。newnode不需要那个内存,但newnode->word确实需要。

strndup()有效,因为它为您分配内存。

如果您仍然难以理解这一点,那么您可能对指针有一些误解。

newnode->word是一个指针。它在某台机器上具有固定大小(例如 8 个字节)。为简单起见,假设listT定义如下:

typedef struct {
    char *word;
} listT;

那么在分配内存的时候,只需要分配8个字节newnode就可以容纳一个指针,然后就需要给那个指针分配内存,用来存放一些字符。


虽然与您的问题无关,但我还想指出,您不应该将malloc(). 请参阅是否强制转换 malloc 的结果?

于 2014-12-27T18:38:25.187 回答