标签:
1 struct { 2 int item; 3 struct list* next; 4 }list;
如果结构体定义如上,使用下面的代码,将会报错
//添加元素,由于我们实现的是单向链表,所以使用从尾部添加 bool AddItem(int a,struct list *plist) { struct list *pNew; struct list *pNode; pNode=plist; pNew=malloc(sizeof( struct list)); if(pNew==NULL) { return false; } pNew->item=a; pNew->next=NULL; if(pNode==NULL) { plist=pNew; }else { while(pNode->next!=NULL) { pNode=pNode->next; } pNode->next=pNew; } return true; }
c30.c: In function ‘AddItem‘:
c30.c:30:22: error: invalid application of ‘sizeof‘ to incomplete type ‘struct list‘
pNew=malloc(sizeof( struct list));
^
c30.c:35:6: error: dereferencing pointer to incomplete type
pNew->item=a;
^
其报错并不在struct处,而是在其使用处。
这是因为结构体定义有问题。
标签:
原文地址:http://www.cnblogs.com/jiudianren/p/5641565.html