C/C++ 中,int型数据地址强制转换成char型再打印出来为什么是反向的?
比如:inta='defg';cout<<(char*)&a<<endl;(当然这个肯定会出错,能跑就行)输出结果是gfed(后面显示的就是乱码了)我想知道为什么输出顺序...
比如:
int a='defg';
cout<<(char*)&a<<endl; (当然这个肯定会出错,能跑就行)
输出结果是 gfed (后面显示的就是乱码了)
我想知道为什么输出顺序是倒着的,难道计算机存int数据是先拆成一个个byte再倒着存的?然后把每个byte的8个bit正着放?&a实际指向的是低位字节(我一直以为指向的是高位的)?
我是想把int里的数据每个byte都以ASCII码转换成一个char字符而形成一个字符串,哪位给点建议哈!有没有快点的方法,sprintf打出来也是倒着的啊,我不想再转过来。 展开
int a='defg';
cout<<(char*)&a<<endl; (当然这个肯定会出错,能跑就行)
输出结果是 gfed (后面显示的就是乱码了)
我想知道为什么输出顺序是倒着的,难道计算机存int数据是先拆成一个个byte再倒着存的?然后把每个byte的8个bit正着放?&a实际指向的是低位字节(我一直以为指向的是高位的)?
我是想把int里的数据每个byte都以ASCII码转换成一个char字符而形成一个字符串,哪位给点建议哈!有没有快点的方法,sprintf打出来也是倒着的啊,我不想再转过来。 展开
展开全部
举个例子来说吧,假设32位整型int a=0x56781234; 而&a=0x80000000,则内存中的字节存储顺序是:
0x80000000 0x04
0x80000001 0x03
0x80000002 0x02
0x80000003 0x01
0x80000004 0x08
0x80000001 0x07
0x80000002 0x06
0x80000003 0x05
即低位字节存储在前,以8个字节为一个32位整型单位,这叫Little Endian式存储方式。
字符串寻址是按照字节单位顺序访问的。
如果上述变量a你要输出12345678的ASCII码顺序,你可以:int a=0x87654321;
一般PC用的cpu采用Little Endian方式存储数据,但有的cpu采用Big Endian方式,那样你就可以采取int a=0x12345678;了。
0x80000000 0x04
0x80000001 0x03
0x80000002 0x02
0x80000003 0x01
0x80000004 0x08
0x80000001 0x07
0x80000002 0x06
0x80000003 0x05
即低位字节存储在前,以8个字节为一个32位整型单位,这叫Little Endian式存储方式。
字符串寻址是按照字节单位顺序访问的。
如果上述变量a你要输出12345678的ASCII码顺序,你可以:int a=0x87654321;
一般PC用的cpu采用Little Endian方式存储数据,但有的cpu采用Big Endian方式,那样你就可以采取int a=0x12345678;了。
追问
可int里的数据是确定的啊,比如'appl',有什么函数可以快点转过来不
追答
没有现成的函数,因为你这样拿int当字符串处理的用法非标准,int里数据是确定的,你可以自己编一个函数完成这个任务。象你那样的赋值方法也有问题,不是所有编译器都能接受的。
建议:字符串数据还是开设成char型或unsigned char型,如果非要用int来访问,可以开int型指针变量来对其寻址。
展开全部
这是指在内存中的排序方式。计算机分为大端排序,小端排序的。
小端排序是指:低位在低地址端。
大端排序:高位在低地址端。
小端排序是指:低位在低地址端。
大端排序:高位在低地址端。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
因为你的机器是小端机器
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
讲起来比较多一些,你到百度百科中看看“字节顺序”
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询