在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个字节。那肯定出错。。