Chinaunix首页 | 论坛 | 博客
  • 博客访问: 72389
  • 博文数量: 10
  • 博客积分: 216
  • 博客等级: 入伍新兵
  • 技术积分: 163
  • 用 户 组: 普通用户
  • 注册时间: 2012-09-21 20:14
文章分类
文章存档

2012年(10)

我的朋友

分类: C/C++

2012-11-14 21:28:13


    机器的字节序有两种,即大端字节序和小端字节序。
    大端字节序:在内存中,低地址存放数据的,高地址存放数据的
    小端字节序:在内存中,低地址存放数据的,高地址存放数据的
    如例:定义数据  a = 0x01020304
          小端方式:01 02 03 04
          大端方式:04 03 02 01
那么如何判断呢,方式如下-->
一、指针方式
    代码如下:
    
    说明:在此我定义了一个全局变量a,方便与用objdump工具查看程序数据段的存储
    如上,定义了一个整形的32位宽的变量 a , 然后用字符型指针强转后解引用并打印出值。整形是占4个字节的,若转成字符型必定会丢失数据,因内存中数据是顺序存储的,所以强转后解引用会取出低一个字节的数据,由此我们可以根据那一个字节的数据来判断到底是大端字节序还是小端。
    如上程序,运行一下,如果打印的结果是4的话表明是小端字节序,是 1 的话表示是大端字节序
    运行程序,结果如下:
    
    打印结果为4,表明我机器的CPU的字节序为小端模式
    下面,用 objdump 工具来验证一下,中断中敲命令,后跟程序的可执行文件
    
    因为我定义的是全局变量,所以查找数据段的内容。在此要用到一个数据,就是我打印的变量 a 的地址,上图:
    
    如上图,a的地址是804a014 ,根据此地址找到基地址 804a00c , 向右偏移8个字节后就是变量 a 的地址, 如红线所示,存储顺序为04030201, 表明是小端字节序。

二、联合体方式
    代码如下:
    
    如上图,欲知此程序的运行结果,我们还需要了解联合体的特性。
    联合体也叫做共用体,即它不同与结构体,它只有一片内存,而且片内存区域是联合体中的所有成员所共享,且它的大小为联合体中最大的那个成员所占的空间,如上图,则它的内存为4个字节。
    由于我们先给 a 赋值,则内存中存放的数据应为 0x00 00 00 01 , 档用字符型的b变量从共享内存中取数据时只能取得低字节的数据, 即 01 。
    在此,如果是小端字节序的话,那么它取得的数据应该是01,如果是大端字节序的话,那么取得的数据应该是 00. 运行程序,结果如下:
    
     如上图,结果为1, 为小端字节序。
阅读(9270) | 评论(8) | 转发(4) |
给主人留下些什么吧!~~

技术斌2012-12-10 12:05:01

sky_sky888: 通过这些预定义宏可以载编译时候确定编译器还有系统的字节序,不必那么麻烦了;
毕竟不是脚本程序,你得先编译C source code啊......
哦  

sky_sky8882012-12-07 18:27:11

技术斌: 嗯,主要是方便查看。你写的这个我没怎么看明白,解释一下下  .....
通过这些预定义宏可以载编译时候确定编译器还有系统的字节序,不必那么麻烦了;
毕竟不是脚本程序,你得先编译C source code啊.

技术斌2012-11-22 20:56:54

visualfan: 大端字节序:在内存中,低地址存放数据的低位,高地址存放数据的高位
    小端字节序:在内存中,低地址存放数据的高位,高地址存放数据的低位

这里好像说反了.....
朋友,是你说反了

visualfan2012-11-21 22:26:26

大端字节序:在内存中,低地址存放数据的低位,高地址存放数据的高位
    小端字节序:在内存中,低地址存放数据的高位,高地址存放数据的低位

这里好像说反了吧

技术斌2012-11-21 20:52:11

M_O_Bz: vim配色不错,是我喜欢的方案。.....
用的是secureCRT 登录VM虚拟机。直接用虚拟机弄来弄去的,我的电脑太卡了