小议大小端模式对C语言的共用体结构的影响


小议大小端模式对C语言的共用体结构的影响

1、一些问题

问题1

[plain]
  1. #include "stdio.h"  
  2. union   
  3. {  
  4.     int i;  
  5.     char ch[2];  
  6. }key;  
  7. main()  
  8. {  
  9.     key.i=65*256+66;  
  10.     printf("%c\t%c\n",key.ch[0],key.ch[1]);  
  11. }  
答案是B      A;为什么不是A      B呢?         在前面的文章中我们已经测试过(相关阅读: 与 ),X86体系结构的CPU是小端模式的。比如一个数0x1234,放在内存里按照内存地址从低往高实际上是低地址字节里放的是0x34,高字节里放的是0x12。小端模式和我们平时感觉上的一致,把数位数越高的部分放在地址越高的部分。union类型是共享内存的,union中是按照从低到高放的,i=0x4142,也就是低地址中放的是42,高地址中放的是41,按照ch[0],ch[1]的顺序输出就是B      A。如果是大端模式的话就是打印两个空了,故不会出现A      B的情况。

问题2

[plain]
  1. union myun   
  2. {  
  3.    struct { int x; int y; int z; }u;   
  4.    int k;   
  5. }a;   
  6. int main()   
  7. {   
  8.    a.u.x =4;  
  9.    a.u.y =5;   
  10.    a.u.z =6;   
  11.    a.k = 0;   
  12.    printf("%d %d %d\n",a.u.x,a.u.y,a.u.z);  
  13.    return 0;  
  14. }  
        union类型是共享内存的,以size最大的结构作为自己的大小,这样的话,myun这个结构就包含u这个结构体,而大小也等于u这个结构体的大小,在内存中的排列为声明的顺序x,y,z从低到高,然后赋值的时候,在内存中,就是x的位置放置4,y的位置放置5,z的位置放置6,现在对k赋值,对k的赋值因为是union,要共享内存,所以从union的首地址开始放置,首地址开始的位置其实是x的位置,这样原来内存中x的位置就被k所赋的值代替了,就变为0了,这个时候要进行打印,就直接看内存里就行了,x的位置也就是k的位置是0,而y,z的位置的值没有改变,所以应该是0,5,6。
  • 1
  • 2
  • 下一页

相关内容