c语言s1e39 测试6 ,和答案结果不一致
http://bbs.fishc.org/thread-80955-1-5.html这是原帖地址#include <stdio.h>
int main(void)
{
char a = 0, b = 0;
int *p = (int *)&b;
*p = 258;
printf("%d %d\n", a, b);
return 0;
}
答案说是1和2,我打印出来怎么是0和2 本帖最后由 人造人 于 2018-7-18 22:26 编辑
想要输出 1 2 ?
可以,第一行必须是 ok
第二行一定是 1 2
输出 1 2 的一个必须的条件:变量a和变量b必须紧挨着,并且变量a在变量b的后面(变量b的地址小,变量a的地址大)
C语言貌似没有规定 变量a和变量b必须紧挨着,并且变量a在变量b的后面
也就是不同编译器可能会有不同的结果,同一编译器的不同版本可能也会有不同的结果
这是反汇编截图 先看
*p = (int *)&b;把p指向了b的地址。
再看
*p = 258; 把p指向的地址赋值为 258
这就可以清楚的知道 b 处 和p 指向都是同一个地方; 不同的是 b占1个字节,而p 是int指向 占4个字节。
258 转换成 二进制 以 小端的形式存储 关于大端小端
258 转 16制制是102
用十六制编辑器查看就是:
02 10
此处的b 只读取1个字节,也就是 02 十进制也就是是2 ba21 发表于 2018-7-18 21:49
先看
*p = (int *)&b;把p指向了b的地址。
再看
我测试了一下,打印是0 2 这是截图 wow7jiao 发表于 2018-7-18 21:55
我测试了一下,打印是0 2
windows 中是打印 0 2啊,没问题啊。
你有没有看 大端和小端啊。
linux 和 windows 使用的是不同的 端
教程用的是linux 你要是觉得有疑问,你就在用linux调试一下不就成了。 ba21 发表于 2018-7-18 21:59
windows 中是打印 0 2啊,没问题啊。
你有没有看 大端和小端啊。
linux 和 windows 使用的是不同的 端
...
windows 是 小端
linux 如果是大端,结果应该是2个0 这是截图 如果linux 是大端,从0x004AFCAB 开始的一个整型数据是 00 00 01 02,就是 a = 0,b = 0 问题出在a和b变量,在内存地址中不连续
vc2010测试。
#include <stdio.h>
int main(void){
char a = 0, b = 0;
int *p = (int *)&b;
*p = 258;
printf("%d %d\n", a, b);
printf("%p %p a和b地址相差距离:%d字节\n",&a,&b,&a-&b);
p=&b+1;
printf("%p %p %d\n",&b,p,*(char *)p);
return 0;
}
说明a和b在内存中地址不是连续的所以在打印的时候会输出0和2
但是b地址+1的内存空间一定是1,结果如下
现在说如果打印1和2的栈情况
因为是连续的所以a是1 b是2,按照高位在高地址的方式存储
页:
[1]