DSP

大端模式和小端模式

2019-07-13 12:28发布

大端模式:是指数据的低位(权值较小的那几位)保存在内存的高地址中,而数据的高位,保存在内存的低地址中 小端模式:是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中、 如:将一个32位的整数0x12 34 56 78存放到一个整型变量(int)中,这个整型变量采用大端或者小端模式在内存中的存储由下表所示:
1)大端模式
2)小端模式

为什么会有大小端模式之分呢? 这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit。但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(看具体的编译器了),另外,对于位数大于8位的处理器,由于寄存器宽度大于一个字节,那么必然存在着如何将多个字节安排的问题,因此就导致了大端存储模式和小端存储模式。
我们常用的X86结构是小端模 式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。 
测试编译器属于哪种模式? 如下代码用来测试编译器是大端模式还是小端模式: #include
int main(void)
{
        short int x;
        char x0, x1;
        x = 0x1122;
        x0 = ((char *)&x)[0];        //低地址单元 
        x1 = ((char *)&x)[1];       //高地址单元 
        printf("x0 = 0x%x, x1 = 0x%x ", x0, x1);
        return 0;
}
若x0=0x11,则是大端; 若x0=0x22,则是小端......
如下代码用来测试处理器是大端模式还是小端模式 #include
int main(void)
{
        int x = 1;
        char* p = (char *)&x;    //如果此时p指向的内存为1的话,则为小端,否则为大端。
        if(*p)
       {
             printf("little ");
       }
      else
       {
             printf("large ");  
       }
       return 0;
}