在今天测试的过程中遇到了这样一个问题,
A.c
char *func(){
char *ptr;
ptr =malloc(14);
return ptr;
}
main.c
int main(){
A=func();
b=strlen(A);
}
结果发现在func()中,ptr = 0x7fff10121010,结果返回的时候A的值确是0xffffffff10121010。在32位的情况下,这个bug是发现不了的。
一开始感觉是gdb的bug,其实还是自己的程序有问题呀。在编译的时候,func()并没有在A.h中声明,这样main函数在编译的时候,符号表中并没有该函数的声明,结果就是默认给该函数分配一个int类型的数作为一个返回值,这样在类型转换的时候ptr(8Bytes)->int(4Bytes)->A(8Bytes)。结果部分信息就丢失了。ptr = 0x7fff10121010就转换成了0xffffffff10121010。
我想 gcc如果能够不设置int为返回值的话,这个问题就不会出现了。
很显然这种情况在32位的情况下是不会出现问题的。但是64位的情况下却会出现问题。
阅读(4099) | 评论(0) | 转发(0) |