簡體   English   中英

c語言編程,鏈表錯誤

[英]c programming, linked list error

當我嘗試編譯以下代碼時,出現錯誤

test.c: In function 'main':
test.c:16: error: incompatible types in assignment

和代碼是..

#include <stdio.h>
#include <ctype.h>
#include <string.h>

typedef struct {
    char name[20];
    struct planet* next;
} planet;


int main(int argc, char *argv[])
{
    planet *p, *start, *first, *second, *third;

    strcpy(start->name, "Suthan");
    start->next = *first;

}

1)為您的指針分配一些內存。

planet *start, *first; these are uninitialized pointers.

start->next // that's dereferencing an uninitialized pointer.

2)你設置開始- >下一個(一個指向地球)的deferenced指針first 這就是錯誤的根源。

start->next = *first;  // should be  = first;

3)移動typedef名稱以擺脫您看到的警告。

typedef struct planet{
   char name[20];
   struct planet* next;
};

因為正在嘗試將planet*first )的實例分配給指向planet的指針( start->next )。

嘗試以下方法:

start->next = first;

但是,我也想知道您對planet的聲明。 這有幫助嗎?

typedef struct _planet {
    char name[20];
    struct _planet* next;
} planet;

我認為您的結構錯誤

typedef struct _planet {
    char name[20];
    struct _planet* next;
} planet;

應該:

typedef struct planet {
char name[20];
struct planet* next;
}

我記得在自我參照結構的這一方面有所突破。

typedef struct {
    char name[20];
    struct planet* next; /* <-- the trouble is here */
} planet;

在struct定義的中間(即在typedef定義的中間),編譯器不知道struct planet外觀,但是很高興讓您定義一個指向它的指針。 直到取消引用*next ,編譯器才真正需要知道它的外觀。 當您到達main()的正文時,您仍然沒有告訴編譯器什么是struct planet ,只有一個叫做planet的類型碰巧是一個未命名的struct。

考慮以下方法。

struct foo {
    int bar;
};

typedef struct foo foo_type;

struct foo bar;
foo_type baz;

這表明結構的名稱是foo ,定義的類型的名稱是foo_type 我可以這樣組合它們:

typedef struct foo {
    int bar;
} foo_type;

您可以通過向內聯結構定義中添加虛擬名稱來解決編譯器警告。

typedef struct planet_struct {
    char name[20];
    struct planet_struct* next;
} planet;

您還需要解決其他人指出的內存分配問題,但這可以回答您實際上並未提出的問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM