关于编译报错“dereferencing pointer to incomplete type...

1
2
3
4
5
6
#include <netinet/ip_icmp.h>
...
struct icmp* aaa;
     aaa = ( struct icmp*) malloc ( sizeof ( struct icmp)); //假设是第200行;
     aaa->icmp_type=1; //假设是201行;
...

make的时候第201行报错:dereferencing pointer to incomplete type。

首先说一下这个报错的意思,通俗的说就是,试图访问该pointer指向的变量,却发现该变量是一个不完整的类型,多出错于访问结构体联合体的成员。从代码中可看出来,是从201行开始才真正的访问icmp_type指向的变量,200行还没访问。

于是我就猜想,是不是struct icmp没有定义呢?遂粗略的查看了/usr/include/netinet/ip_icmp.h文件,发现有struct icmp的定义。很奇怪,不是吗?经过写了一些demo测试,最终的结论是,确实没有struct icmp的定义!

看到这里,更奇怪了。为什么是这样的结论呢?细看/usr/include/netinet/ip_icmp.h文件,会发现struct icmp的定义被包含在一个宏里面j,如下面所示:

?
1
2
3
4
5
6
7
8
9
...
#ifdef __USE_BSD
...
struct icmp {
...
}
...
#endif /*END OF ifdef __USE_BSD*/
...

看到这里应该就明白了,编译的时候,如果编译命令 gcc ...里面没有加入 -D__USE_BSD的话,那么struct icmp的定义是不会被include进来的,所以就导致了前面的第201行报错:dereferencing pointer to incomplete type,也就是这样导致我开始一直想不明白,明明有定义,为何却说是不完整的类型。于是为了验证这个结论,我写了一个小demo来测试,发现加 -D__USE_BSD就编译通过,否则就编译不通过。

在解决这个问题的过程中,我写了不少demo,,下面总结一下。

1.如果报错“dereferencing pointer to incomplete type”,先试图找一下该行的那个结构体变量的定义是否能找到,可使用grep "struct xxx" /usr/include -R命令递归搜索/usr/include目录,如找到,可在.c文件中#include,如果是非标准头文件就要在编译命令中加入-I头文件目录,例如(-I/usr/local/xxx/include)。

2.如果#include之后仍然报错“dereferencing pointer to incomplete type”,试图仔细查看该文件,查看该结构体的定义是否被某个编译宏给包裹了,如果确实处于某个编译宏的包裹内,在编译命令里面增加 -D编译宏(如-D__USE_BSD)

经过上面两个步骤以后,基本上能解决“dereferencing pointer to incomplete type”报错了。


文章出处:http://my.oschina.net/michaelyuanyuan/blog/68203

在C语言编程中,错误信息“dereferencing pointer to incomplete type”通常表示你正在尝试解引用一个指向不完整类型的指针。这意味着编译器在当前作用域中只能看到该类型的一部分定义,而无法完全理解该类型的所有细节,因此无法安全地解引用该指针。 这种情况常见于以下几种场景: 1. **不完整的结构体定义**:如果你在一个头文件中声明了一个结构体,但在实现文件中没有包含完整的定义,编译器会认为该结构体是不完整的。 2. **前向声明**:使用前向声明(forward declaration)时,编译器只知道类型的名字,而不知道其具体成员。 3. **缺少头文件**:如果某个结构体或类的定义在另一个头文件中,而你忘记包含该头文件,编译器也会认为该类型是不完整的。 例如: ```c // incomplete_type.h struct IncompleteType; // dereferencing.c #include <stdio.h> #include "incomplete_type.h" int main() { struct IncompleteType *ptr; // 以下代码会导致编译错误 // printf("%d\n", ptr->member); return 0; } ``` 在上述代码中,`struct IncompleteType` 是一个不完整的类型,因为没有提供其完整的定义。因此,尝试解引用 `ptr->member` 会导致编译错误。 要解决这个问题,你需要提供结构体的完整定义: ```c // complete_type.h struct CompleteType { int member; }; // dereferencing.c #include <stdio.h> #include "complete_type.h" int main() { struct CompleteType *ptr = malloc(sizeof(struct CompleteType)); ptr->member = 10; printf("%d\n", ptr->member); free(ptr); return 0; } ``` 通过提供完整的结构体定义,编译器能够理解 `ptr->member` 的含义,从而避免错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值