wow7jiao 发表于 2018-7-18 20:20:48

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 20:20:49

本帖最后由 人造人 于 2018-7-18 22:26 编辑





想要输出 1 2 ?
可以,第一行必须是 ok
第二行一定是 1 2

输出 1 2 的一个必须的条件:变量a和变量b必须紧挨着,并且变量a在变量b的后面(变量b的地址小,变量a的地址大)
C语言貌似没有规定 变量a和变量b必须紧挨着,并且变量a在变量b的后面
也就是不同编译器可能会有不同的结果,同一编译器的不同版本可能也会有不同的结果

wow7jiao 发表于 2018-7-18 20:21:26

这是反汇编截图

ba21 发表于 2018-7-18 21:49:25

先看
*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

wow7jiao 发表于 2018-7-18 21:55:19

ba21 发表于 2018-7-18 21:49
先看
*p = (int *)&b;把p指向了b的地址。
再看


我测试了一下,打印是0 2

wow7jiao 发表于 2018-7-18 21:55:51

这是截图

ba21 发表于 2018-7-18 21:59:36

wow7jiao 发表于 2018-7-18 21:55
我测试了一下,打印是0 2

windows 中是打印 0 2啊,没问题啊。
你有没有看 大端和小端啊。
linux 和 windows 使用的是不同的 端

教程用的是linux 你要是觉得有疑问,你就在用linux调试一下不就成了。

wow7jiao 发表于 2018-7-18 22:07:45

ba21 发表于 2018-7-18 21:59
windows 中是打印 0 2啊,没问题啊。
你有没有看 大端和小端啊。
linux 和 windows 使用的是不同的 端
...

windows 是 小端

linux 如果是大端,结果应该是2个0

wow7jiao 发表于 2018-7-18 22:10:17

这是截图

wow7jiao 发表于 2018-7-18 22:12:08

如果linux 是大端,从0x004AFCAB 开始的一个整型数据是 00 00 01 02,就是 a = 0,b = 0

关键是感觉 发表于 2018-7-18 23:00:50

问题出在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]
查看完整版本: c语言s1e39 测试6 ,和答案结果不一致