Welcome 微信登录
编程资源 图片资源库 蚂蚁家优选 PDF转换器

首页 / 操作系统 / Linux / 小议大小端模式对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 %c ",key.ch[0],key.ch[1]);  
  11. }  
答案是B      A;为什么不是A      B呢?        在前面的文章中我们已经测试过(相关阅读:http://www.linuxidc.com/Linux/2012-02/53889.htm 与 http://www.linuxidc.com/Linux/2012-02/53890.htm),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 ",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。