写过类似下面的代码,但是两个fprintf的结果不一样。
在a.c 文件中有。
void *d = foo_create();
fprintf(stderr, "2..addr = %p", d);
在b.c 文件中有。
void *foo_create() {
d = malloc(1);
fprintf(stderr, "1..addr = %p", d);
return d;
}
分析过程
在老大的帮助下。
gdb 断点,再用disass 看下汇编。
出现类似mov %rax, %eax 的语句。
用c的方式理解,把八个字节的值强转为4个字节。
结论
由于隐式声明导致这个问题出现的。
隐式声明的函数返回值为int,在64位机器上。如果要返回大于int(4个字节的)值,就会出错。比如要返回一个地址,并且这个地址大于4个字节。那肯定出错。。