[英]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.