short a[5] = { 0, 1, 2, 3, 4 };
int* p = (int*)a;
p++;
printf(" *p = %d\n", *p); //196610
上面的代码我预期的输出结果应该是770,十六进制是0x0302
但是我调试后,查看编译器的显示情况,结果196610的十六进制是0x00030002,生生的多了好几个的double 0啊
再查看数组a 的十六进制数值
{0x0000, 0x0001, 0x0002, 0x0003, 0x0004}
好了我的问题来了,数组a 的十六进制数值不应该是下面这样子的么?
{0x00, 0x01, 0x02, 0x03, 0x04}
最关键的是用sizeof查看short的大小,还是依然sizeof(short) = 2! sizeof(a) = 10!
完全一脸懵逼了!求大神解答。
注:我的操作系统是win10 64位,编译器是VS2013旗舰版,好像也是64位版本的
几个意思阿,short是两个字节,就应该是0xFFFF之类的值。。。
查看字节的大小要看编译器目标平台,不是看你的自身操作系统是多少位,比如你的目标平台指定是x86。
全选复制放进笔记
{0x0000, 0x0001, 0x0002, 0x0003, 0x0004}
^
p(int *)
//之后 p ++
{0x0000, 0x0001, 0x0002, 0x0003, 0x0004}
^
p(int *)
因为你的平台是小端,所以是0x00030002
,即196610。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。