展开全部
union是联合体,其中的所有变量共用一片内存空间,该空间长度为union中最长的变量长度,即int数组i[2]的长度8。
union会牵涉到大小端问题,而题中给出的数组的第0个元素在低位并不能说明机器为大端序还是小端序,因为数组的生长方向永远向上,和大小端以及堆栈的生长方向没有关系。这意味着这道题目是有很严重的问题的,因为它并没有说明机器是大端序还是小端序,而给出的答案只在小端序下才成立。
假设机器是小端序,那么s->i[0]=0x39会将union的低四个字节写为39 00 00 00,s->i[1]=0x38会将union的高四个字节写为38 00 00 00。此时整个union的数据是:低39 00 00 00 38 00 00 00高
对于union中的char c[4]数组来说,它会使用第0~3个字节作为自己的4个元素,即c[0]~c[3]分别为39、00、00、00。这里的39是十六进制的0x39,换算成十进制就是57。接着以%c格式输出c[0],最终输出的就是57的ASCII码对应的字符'9'。
而如果机器是大端序的话,那么结果将完全不同。
union会牵涉到大小端问题,而题中给出的数组的第0个元素在低位并不能说明机器为大端序还是小端序,因为数组的生长方向永远向上,和大小端以及堆栈的生长方向没有关系。这意味着这道题目是有很严重的问题的,因为它并没有说明机器是大端序还是小端序,而给出的答案只在小端序下才成立。
假设机器是小端序,那么s->i[0]=0x39会将union的低四个字节写为39 00 00 00,s->i[1]=0x38会将union的高四个字节写为38 00 00 00。此时整个union的数据是:低39 00 00 00 38 00 00 00高
对于union中的char c[4]数组来说,它会使用第0~3个字节作为自己的4个元素,即c[0]~c[3]分别为39、00、00、00。这里的39是十六进制的0x39,换算成十进制就是57。接着以%c格式输出c[0],最终输出的就是57的ASCII码对应的字符'9'。
而如果机器是大端序的话,那么结果将完全不同。
展开全部
上面大牛的回答太深有点难懂。我们初学还是理解点皮毛吧。
记住:共用体不同于结构体,会共有一处空间,对于其中一个成员的赋值,会影响到另一个成员。
其实就是s->i[0]的地址被s->c[0]转换为char类型输出了,复制一下运行试试,望采纳。
#include <iostream>
using namespace std;
int count=1;
int main()
{
union
{
int a[2];
long b;
char c[4];
}r,*s=&r;
s->a[0]=0x56;
cout<<s->a[0]<<"转换char型"<<static_cast<char>(s->a[0])<<endl; //把s->a[0]强制转为char输出来
s->a[1]=0x38;
cout<<s->a[1]<<"转换char型"<<static_cast<char>(s->a[1])<<endl;
cout<<s->c[0]<<"转换int型"<<static_cast<int>(s->c[0])<<endl; //把s->c[0]强制转为int输出来
system("pause");
return 0;
}
记住:共用体不同于结构体,会共有一处空间,对于其中一个成员的赋值,会影响到另一个成员。
其实就是s->i[0]的地址被s->c[0]转换为char类型输出了,复制一下运行试试,望采纳。
#include <iostream>
using namespace std;
int count=1;
int main()
{
union
{
int a[2];
long b;
char c[4];
}r,*s=&r;
s->a[0]=0x56;
cout<<s->a[0]<<"转换char型"<<static_cast<char>(s->a[0])<<endl; //把s->a[0]强制转为char输出来
s->a[1]=0x38;
cout<<s->a[1]<<"转换char型"<<static_cast<char>(s->a[1])<<endl;
cout<<s->c[0]<<"转换int型"<<static_cast<int>(s->c[0])<<endl; //把s->c[0]强制转为int输出来
system("pause");
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询