C语言中判断大小端的方法

摘自:http://blog.csdn.net/fei324/article/details/6887608

存储器模式(大端、小端模式)

C语言中判断大小端的方法

有时候,用C语言写程序时需要知道是大端模式还是小端模式。 所谓的大端模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;小端模式相反。为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。例如一个16bit的short型x,在内存中的地址为0x0010,x的值为0x1122,那么0x11为高字节,0x22为低字节。对于大端模式,就将0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,刚好相反。我们常用的X86结构是小端模式,而KEIL-C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。

下面这段代码可以用来测试一下你的编译器是大端模式还是小端模式:

short int x;
char x0,x1;
x=0x1122;
x0=((char*)&x)[0];  //低地址单元
x1=((char*)&x)[1];  //高地址单元
若x0=0x11,则是大端; 若x0=0x22,则是小端......

 

存储器模式(SMALL LARGE COMPACT)
C51 提供了3 种存储器模式来存储变量过程参数和分配再入函数堆栈你应该尽量
使用小存储器模式,很少应用系统需要使用其它两种模式。像有大的再入函数堆栈系统那
样一般来说如果系统所需要的内存数小于内部RAM 数时都应以小存储模式进行编译,
在这种模式下DATA 段是所有内部变量和全局变量的默认存储段所有参数传递都发生在
DATA 段中。如果有函数被声明为再入函数编译器会在内部RAM 中为他们分配空间,这种模式的优势就是数据的存取速度很快,但只有120 个字节的存储空间供你使用总共有128个字节,但至少有8 个字节被寄存器组使用你还要为程序调用开辟足够的堆栈
如果你的系统有256 字节或更少的外部RAM 你可以使用压缩存储模式,这样一来
如果不加说明,变量将被分配在PDATA 段中,这种模式将扩充你能够使用的RAM 数量对XDATA 段以外的数据存储仍然是很快的变量的参数传递,将在内部RAM 中进行,这样存储速度会比较快,对PDATA 段的数据的寻址是通过R0 和R1 进行间接寻址比使用DPTR 要快一些,在大存储模式中所有变量的默认存储区是XDATA 段,Keil C 尽量使用内部寄存器组进行参数传递,在寄存器组中可以传递参数的数量和和压缩存储模式一样再入函数的模拟栈将在XDATA 中,对XDATA 段数据的访问是最慢的,所以要仔细考虑变量应存储的位置使数据的存储速度得到优化。


 

posted @ 2012-02-25 21:37  wdliming  阅读(344)  评论(0编辑  收藏  举报