精华内容
参与话题
问答
  • 大端和小端

    千次阅读 2015-07-06 18:49:14
    下面所说的顺序对于存储器来说都是从...大端(big endian)规则:在存储器中按照最高有效字节到最低有效字节的顺序存储对象。 大多数IBM和Sun Microsystems的机器采用这种规则,只是大多数,不是按照企业来划分,IBM和Su

    下面所说的顺序对于存储器来说都是从低地址到高地址:

    基本概念

    小端(little endian)存储:在存储器中按照最低有效字节到最高有效字节的顺序存储对象。
    大多数Intel兼容机采用这种规则。
    大端(big endian)规则:在存储器中按照最高有效字节到最低有效字节的顺序存储对象。
    大多数IBM和Sun Microsystems的机器采用这种规则,只是大多数,不是按照企业来划分,IBM和Sun的制造的个人计算机使用的是Intel兼容的处理器(小端法)。
    双端法(bi-endian):有些比较新的微处理器使用双端法(bi-endian),可以把它们配置成作为大端或者小端的机器运行。

    示例

    假设一个int数值,位于地址0x100处,它的16进制值是0x01234567,那么它们在虚拟存储器中的排列位置如下:
    这里写图片描述

    注意:在字0x01234567,高位字节的十六进制值为0x01,而低位字节值为0x67。

    区别

    但是到底是使用大端还是小端的字节顺序存储,没有技术上的差别。对我们来说,机器所使用的字节顺序是完全不可见的,无论为哪种类型的机器编译的程序都会得到相同的结果。但是字节顺序会成为问题:

    1. 在不同类型的机器之间通过网络传送二进制的数据时,一个常见的问题就是当小端法机器产生的数据被送到大端法机器或者反方向发送时会发现,接收程序字里的字节成了反序的。为了避免这个问题,网络应用程序的代码编写必须遵守已经建立的关于字节顺序的规则,以确保发送方机器将它的内部表示转换成网络标准,而接收方机器则将网络标准装换成它的内部表示。
    2. 阅读表示整数数据的字节序列时字节顺序也很重要,一般是在小端法机器上,当阅读小端法机器生成的机器级程序时,经常会将字节按照相反的顺序显示,主要是因为书写字节序列的时候从左到右是最低位字节到最高位字节(从低地址到高地址),但是书写数字时则是从左到右从高位到低位,在小端机器上正好相反。
      下面的代码是由反汇编器生成的,是Intel IA32处理器的机器级代码的文本表示:
      80483bd: 01 05 64 94 04 08 add %eax,0x8049464
      可以看出十六进制字符串01 05 64 94 04 08是一条指令的字节级表示,这条指令把一个字长的数据加到存储在主存地址0x8049464的值上。我们可以发现这个字节序列的后四个字节就是add指令右边的数值,但是是相反的顺序,这个就是小端法的阅读上的缺点。
    3. 强制类型转化(cast)时,会发现int类型12345和float类型12345.0,都是4个字节,但是每个字节的值不同。
    展开全文
  • C语言再学习-- 大端小端详解(转)

    万次阅读 多人点赞 2017-01-14 19:23:57
    参看:详解大端模式和小端模式 一、什么是大端和小端 所谓的大端模式,就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端。 所谓的小端模式,就是低位字节排放在内存的低地址端,高位字节排放在...

    参看:详解大端模式和小端模式

    一、什么是大端和小端

    所谓的大端模式,就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端。

    所谓的小端模式,就是低位字节排放在内存的低地址端,高位字节排放在内存的高地址端。

    简单来说:大端——高尾端,小端——低尾端

    举个例子,比如数字 0x12 34 56 78在内存中的表示形式为:

    1)大端模式:

    低地址 -----------------> 高地址

    0x12  |  0x34  |  0x56  |  0x78

    2)小端模式:

    低地址 ------------------> 高地址

    0x78  |  0x56  |  0x34  |  0x12

    可见,大端模式和字符串的存储模式类似。

    3)下面是两个具体例子:

    16bit宽的数0x1234在Little-endian模式(以及Big-endian模式)CPU内存中的存放方式(假设从地址0x4000开始存放)为:

    内存地址 小端模式存放内容 大端模式存放内容
    0x4000 0x34 0x12
    0x4001 0x12 0x34

    32bit宽的数0x12345678在Little-endian模式以及Big-endian模式)CPU内存中的存放方式(假设从地址0x4000开始存放)为:

    内存地址 小端模式存放内容 大端模式存放内容
    0x4000 0x78 0x12
    0x4001 0x56 0x34
    0x4002 0x34 0x56
    0x4003 0x12 0x78
     

    4)大端小端没有谁优谁劣,各自优势便是对方劣势:

    小端模式 :强制转换数据不需要调整字节内容,1、2、4字节的存储方式一样。
    大端模式 :符号位的判定固定为第一个字节,容易判断正负。

    二、数组在大端小端情况下的存储:

      以unsigned int value = 0x12345678为例,分别看看在两种字节序下其存储情况,我们可以用unsigned char buf[4]来表示value:
      Big-Endian: 低地址存放高位,如下:
    高地址
            ---------------
            buf[3] (0x78) -- 低位
            buf[2] (0x56)
            buf[1] (0x34)
            buf[0] (0x12) -- 高位
            ---------------
            低地址
    Little-Endian: 低地址存放低位,如下:
    高地址
            ---------------
            buf[3] (0x12) -- 高位
            buf[2] (0x34)
            buf[1] (0x56)
            buf[0] (0x78) -- 低位
            --------------
    低地址

    三、为什么会有大小端模式之分呢?

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

    四、如何判断机器的字节序 (重点)

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

    #include <stdio.h>
    int main (void)
    {
    	union
    	{
    		short i;
    		char a[2];
    	}u;
    	u.a[0] = 0x11;
    	u.a[1] = 0x22;
    	printf ("0x%x\n", u.i);  //0x2211 为小端  0x1122 为大端
    	return 0;
    }
    输出结果:
    0x2211

    union 型数据所占的空间等于其最大的成员所占的空间。对 union 型的成员的存取都是相对于该联合体基地址的偏移量为 0 处开始,也就是联合体的访问不论对哪个变量的存取都是从 union 的首地址位置开始

    联合是一个在同一个存储空间里存储不同类型数据的数据类型。这些存储区的地址都是一样的,联合里不同存储区的内存是重叠的,修改了任何一个其他的会受影响。

    参看:C语言再学习 -- 结构和其他数据形式

    1. 共用体声明和共用体变量定义
    共用体(参考“共用体”百科词条)是一种特殊形式的变量,使用关键字union来定义
    共用体(有些人也叫"联合")声明和共用体变量定义与结构体十分相似。其形式为:
    union 共用体名{
    数据类型 成员名;
    数据类型 成员名;
    ...
    } 变量名;

    参看:

    共用体表示几个变量共用一个内存位置,在不同的时间保存不同的数据类型和不同长度的变量。在union中,所有的共用体成员共用一个空间,并且同一时间只能储存其中一个成员变量的值

    下例表示声明一个共用体foo:

    union foo{/*“共用”类型“FOO”*/
        int i;    /*“整数”类型“i”*/
        char c;   /*“字符”类型“C”*/
        double k;  /*“双”精度类型“K”*/
    };

    再用已声明的共用体可定义共用体变量。例如,用上面说明的共用体定义一个名为bar的共用体变量, 可写成:
    union foo bar;
    在共用体变量bar中, 整型变量 i 和字符变量 c 共用同一内存位置。

    当一个共用体被声明时, 编译程序自动地产生一个变量, 其长度为联合中最大的变量长度的整数倍。以上例而言,最大长度是double数据类型,所以foo的内存空间就是double型的长度。

    union foo/*“共用”类型“FOO”*/
    {
        char s[10];    /*“字符”类型的数组“S”下面有“10”个元素*/
        int i;        /*“整数”类型i*/
    };

    在这个union中,foo的内存空间的长度为12,是int型的3倍,而并不是数组的长度10。若把int改为double,则foo的内存空间为16,是double型的两倍。

    2. 共用体和结构体的区别
    1)共用体和结构体都是由多个不同的数据类型成员组成, 但在任何同一时刻, 共用体只存放了一个被选中的成员, 而结构体的所有成员都存在。
    2.)对于共用体的不同成员赋值, 将会对其它成员重写, 原来成员的值就不存在了, 而对于结构体的不同成员赋值是互不影响的。

    总结:

    恍然大悟,union 联合之前还是没有理解透。一开始不太理解,为什么给 a[0]、a[1] 赋值,i 没有定义啊,为什么会有值呢,或者值为什么不是随机数呢?现在明白了,我们为什么用 union 联合来测试大小端,在联合变量 u 中, 短整型变量 i 和字符数组 a 共用同一内存位置。给 a[0]、a[1] 赋值后,i  也是从同一内存地址读值的。

    知道这层关系后,那么通过强制类型转换,判断其实存储位置,也可以测试大小端了:

    #include <stdio.h>
    int main (void)
    {
    	short i = 0x1122;
    	char *a = (char*)(&i);
    	printf ("0x%x\n", *(a + 0)); //大端为 0x11 小端为 0x22
    	printf ("0x%x\n", *(a + 1));
    	return 0;
    }
    输出结果:
    0x22
    0x11
    

     

    说明:上面两个例子,可以通过 if 语句来判断大小端,这里只是介绍方法。

    五、常见的字节序

    一般操作系统都是小端,而通讯协议是大端的。

    1)常见CPU的字节序

    Big Endian : PowerPC、IBM、Sun
    Little Endian : x86、DEC
    ARM既可以工作在大端模式,也可以工作在小端模式。

    2)常见文件的字节序

    Adobe PS – Big Endian
    BMP – Little Endian
    DXF(AutoCAD) – Variable
    GIF – Little Endian
    JPEG – Big Endian
    MacPaint – Big Endian
    RTF – Little Endian

    另外,Java和所有的网络通讯协议都是使用Big-Endian的编码。

    六、如何进行大小端转换(重点)

    第一种方法:位操作

    #include<stdio.h>  
      
    typedef unsigned int uint_32 ;  
    typedef unsigned short uint_16 ;  
    
    //16位
    #define BSWAP_16(x) \
        (uint_16)((((uint_16)(x) & 0x00ff) << 8) | \
                  (((uint_16)(x) & 0xff00) >> 8) \
                 )
                 
    //32位               
    #define BSWAP_32(x) \
        (uint_32)((((uint_32)(x) & 0xff000000) >> 24) | \
                  (((uint_32)(x) & 0x00ff0000) >> 8) | \
                  (((uint_32)(x) & 0x0000ff00) << 8) | \
                  (((uint_32)(x) & 0x000000ff) << 24) \
                 )  
    
    //无符号整型16位  
    uint_16 bswap_16(uint_16 x)  
    {  
        return (((uint_16)(x) & 0x00ff) << 8) | \
               (((uint_16)(x) & 0xff00) >> 8) ;  
    }  
    
    //无符号整型32位
    uint_32 bswap_32(uint_32 x)  
    {  
        return (((uint_32)(x) & 0xff000000) >> 24) | \
               (((uint_32)(x) & 0x00ff0000) >> 8) | \
               (((uint_32)(x) & 0x0000ff00) << 8) | \
               (((uint_32)(x) & 0x000000ff) << 24) ;  
    }  
    
    int main(int argc,char *argv[])  
    {  
        printf("------------带参宏-------------\n");  
        printf("%#x\n",BSWAP_16(0x1234)) ;  
        printf("%#x\n",BSWAP_32(0x12345678));  
        printf("------------函数调用-----------\n");  
        printf("%#x\n",bswap_16(0x1234)) ;  
        printf("%#x\n",bswap_32(0x12345678));  
          
        return 0 ;  
    }  
    输出结果:
    ------------带参宏-------------
    0x3412
    0x78563412
    ------------函数调用-----------
    0x3412
    0x78563412
    

     

    这里有个思考?上面的哪个是转换为大端,哪个是转为小端了呢?

    参看:STM32开发 -- 进制与字符串间的转换

    举个例子,比如数字 0x12 34 56 78在内存中的表示形式为:

    1)大端模式:

    低地址 -----------------> 高地址

    0x12  |  0x34  |  0x56  |  0x78

    2)小端模式:

    低地址 ------------------> 高地址

    0x78  |  0x56  |  0x34  |  0x12

    则:

    转换为大端:

    pPack[2] = (u8)((len >> 8) & 0xFF);
    pPack[3] = (u8)(len & 0xFF);

    转为为小端:

    pPack[2] = (u8)(len & 0xFF);

    pPack[3] =  (u8)((len >> 8) & 0xFF);

     

    第二种方法:

    从软件的角度理解端模式

    使用 htonl, htons, ntohl, ntohs 等函数

    参看:百度百科--htonl ()函数

    参看:百度百科--htons ()函数

     

    查看:man htonl

    NAME
           htonl, htons, ntohl, ntohs - convert values between host and network byte order
    
    SYNOPSIS
           #include <arpa/inet.h>
    
           uint32_t htonl(uint32_t hostlong);
    
           uint16_t htons(uint16_t hostshort);
    
           uint32_t ntohl(uint32_t netlong);
    
           uint16_t ntohs(uint16_t netshort);
    
    DESCRIPTION
           The htonl() function converts the unsigned integer hostlong from host byte order to network byte order.
    
           The htons() function converts the unsigned short integer hostshort from host byte order to network byte order.
    
           The ntohl() function converts the unsigned integer netlong from network byte order to host byte order.
    
           The ntohs() function converts the unsigned short integer netshort from network byte order to host byte order.
    
           On  the  i386  the host byte order is Least Significant Byte first, whereas the network byte order, as used on the Internet, is Most
           Significant Byte first.
    

    翻译:

    htonl()     //32位无符号整型的主机字节顺序到网络字节顺序的转换(小端->>大端)
    htons()
        //16位无符号短整型的主机字节顺序到网络字节顺序的转换  (小端->>大端)
    ntohl()     //32位无符号整型的网络字节顺序到主机字节顺序的转换  (大端->>小端)
    ntohs()     //16位无符号短整型的网络字节顺序到主机字节顺序的转换  (大端->>小端)

    注,主机字节顺序,X86一般多为小端(little-endian),网络字节顺序,即大端(big-endian);

     

    举两个小例子:

    //示例一
    #include <stdio.h>
    #icnlude <arpa/inet.h>
    int main (void)
    {
    	union
    	{
    		short i;
    		char a[2];
    	}u;
    	u.a[0] = 0x11;
    	u.a[1] = 0x22;
    	printf ("0x%x\n", u.i);  //0x2211 为小端  0x1122 为大端
    	printf ("0x%.x\n", htons (u.i)); //大小端转换 
    	return 0;
    }
    输出结果:
    0x2211
    0x1122
    
    //示例二
    #include <stdio.h> 
    #include <arpa/inet.h> 
    struct ST{  
        short val1;  
        short val2;  
    };  
    union U{  
        int val;  
        struct ST st;  
    };  
       
    int main(void)  
    {  
        int a = 0;  
        union U u1, u2;  
       
        a = 0x12345678;  
        u1.val = a;  
        printf("u1.val is 0x%x\n", u1.val);  
        printf("val1 is 0x%x\n", u1.st.val1);  
        printf("val2 is 0x%x\n", u1.st.val2);  
        printf("after first convert is: 0x%x\n", htonl(u1.val));  
        u2.st.val2 = htons(u1.st.val1);  
        u2.st.val1 = htons(u1.st.val2);  
        printf("after second convert is: 0x%x\n", u2.val);  
        return 0;  
    }  
    输出结果:
    u1.val is 0x12345678
    val1 is 0x5678
    val2 is 0x1234
    after first convert is: 0x78563412
    after second convert is: 0x78563412

     

    在对普通文件进行处理也需要考虑端模式问题。在大端模式的处理器下对文件的32,16位读写操作所得到的结果与小端模式的处理器不同。单纯从软件的角度理解上远远不能真正理解大小端模式的区别。事实上,真正的理解大小端模式的区别,必须要从系统的角度,从指令集,寄存器和数据总线上深入理解,大小端模式的区别。

     

    以下内容了解:

    1、从系统的角度理解端模式

    先补充两个关键词,MSB和LSB:
      MSB:MoST Significant Bit ------- 最高有效位
            LSB:Least Significant Bit ------- 最低有效位

            处理器在硬件上由于端模式问题在设计中有所不同。从系统的角度上看,端模式问题对软件和硬件的设计带来了不同的影响,当一个处理器系统中大小端模式同时存在时,必须要对这些不同端模式的访问进行特殊的处理。
           PowerPC处理器主导网络市场,可以说绝大多数的通信设备都使用PowerPC处理器进行协议处理和其他控制信息的处理,这也可能也是在网络上的绝大多数协议都采用大端编址方式的原因。因此在有关网络协议的软件设计中,使用小端方式的处理器需要在软件中处理端模式的转变。而Pentium主导个人机市场,因此多数用于个人机的外设都采用小端模式,包括一些在网络设备中使用的PCI总线,Flash等设备,这也要求在硬件设计中注意端模式的转换。
           本文提到的小端外设是指这种外设中的寄存器以小端方式进行存储,如PCI设备的配置空间,NOR FLASH中的寄存器等等。对于有些设备,如DDR颗粒,没有以小端方式存储的寄存器,因此从逻辑上讲并不需要对端模式进行转换。在设计中,只需要将双方数据总线进行一一对应的互连,而不需要进行数据总线的转换。
           如果从实际应用的角度说,采用小端模式的处理器需要在软件中处理端模式的转换,因为采用小端模式的处理器在与小端外设互连时,不需要任何转换。而采用大端模式的处理器需要在硬件设计时处理端模式的转换。大端模式处理器需要在寄存器,指令集,数据总线及数据总线与小端外设的连接等等多个方面进行处理,以解决与小端外设连接时的端模式转换问题。在寄存器和数据总线的位序定义上,基于大小端模式的处理器有所不同。
           一个采用大端模式的32位处理器,如基于E500内核的MPC8541,将其寄存器的最高位msb(most significant bit)定义为0,最低位lsb(lease significant bit)定义为31;而小端模式的32位处理器,将其寄存器的最高位定义为31,低位地址定义为0。与此向对应,采用大端模式的32位处理器数据总线的最高位为0,最高位为31;采用小端模式的32位处理器的数据总线的最高位为31,最低位为0。         
           大小端模式处理器外部总线的位序也遵循着同样的规律,根据所采用的数据总线是32位,16位和8位,大小端处理器外部总线的位序有所不同。大端模式下32位数据总线的msb是第0位,MSB是数据总线的第0~7的字段;而lsb是第31位,LSB是第24~31字段。小端模式下32位总线的msb是第31位,MSB是数据总线的第31~24位,lsb是第0位,LSB是7~0字段。大端模式下16位数据总线的msb是第0位,MSB是数据总线的第0~7的字段;而lsb是第15位,LSB是第8~15字段。小端模式下16位总线的msb是第15位,MSB是数据总线的第15~7位,lsb是第0位,LSB是7~0字段。大端模式下8位数据总线的msb是第0位,MSB是数据总线的第0~7的字段;而lsb是第7位,LSB是第0~7字段。小端模式下8位总线的msb是第7位,MSB是数据总线的第7~0位,lsb是第0位,LSB是7~0字段。
             由上分析,我们可以得知对于8位,16位和32位宽度的数据总线,采用大端模式时数据总线的msb和MSB的位置都不会发生变化,而采用小端模式时数据总线的lsb和LSB位置也不会发生变化。
             为此,大端模式的处理器对8位,16位和32位的内存访问(包括外设的访问)一般都包含第0~7字段,即MSB。小端模式的处理器对8位,16位和32位的内存访问都包含第7~0位,小端方式的第7~0字段,即LSB。由于大小端处理器的数据总线其8位,16位和32位宽度的数据总线的定义不同,因此需要分别进行讨论在系统级别上如何处理端模式转换。在一个大端处理器系统中,需要处理大端处理器对小端外设的访问。

    2、实际中的例子


           虽然很多时候,字节序的工作已由编译器完成了,但是在一些小的细节上,仍然需要去仔细揣摩考虑,尤其是在以太网通讯、MODBUS通讯、软件移植性方面。这里,举一个MODBUS通讯的例子。在MODBUS中,数据需要组织成数据报文,该报文中的数据都是大端模式,即低地址存高位,高地址存低位。假设有一16位缓冲区m_RegMW[256],因为是在x86平台上,所以内存中的数据为小端模式:m_RegMW[0].low、m_RegMW[0].high、m_RegMW[1].low、m_RegMW[1].high……
    为了方便讨论,假设m_RegMW[0] = 0x3456; 在内存中为0x56、0x34。
           现要将该数据发出,如果不进行数据转换直接发送,此时发送的数据为0x56,0x34。而Modbus是大端的,会将该数据解释为0x5634而非原数据0x3456,此时就会发生灾难性的错误。所以,在此之前,需要将小端数据转换成大端的,即进行高字节和低字节的交换,此时可以调用步骤五中的函数BigtoLittle16(m_RegMW[0]),之后再进行发送才可以得到正确的数据。

     

    展开全文
  • 大端小端

    千次阅读 2018-09-30 13:28:04
    我们常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。 Note:采用大端方式进行数据存放符合人类的正常思维,而采用小端...

    • 网络字节序:TCP/IP各层协议将字节序定义为Big-Endian,因此TCP/IP协议中使用的字节序通常称之为网络字节序。
    • 我们常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。
    • Note:采用大端方式进行数据存放符合人类的正常思维,而采用小端方式进行数据存放利于计算机处理。

    #include<stdio.h>
    int main()
    {
        int a = 0x01020304;
        char *b = (char *)&a;

        printf("%08X\n", a);
        printf("%02X,%02X,%02X,%02X \n", b[0], b[1], b[2], b[3]);
        printf("%X,%X,%X,%X \n", (unsigned int )&b[0], (unsigned int )&b[1], (unsigned int )&b[2], (unsigned int )&b[3]);

        union w{
            int c;
            char d[4];
        }e;
        e.c = 0x01020304;
        printf("%02X,%02X,%02X,%02X\n",e.d[0],e.d[1],e.d[2],e.d[3]);
        return 0;
    }
     

    x86:小端,起始地址存放低位字节(little-endian

    01020304
    04,03,02,01
    3FE37A7C,3FE37A7D,3FE37A7E,3FE37A7F
    04,03,02,01

     

    大端,起始地址存放高位字节(big-edian

    01020304
    01,02,03,04
    BE805D48,BE805D49,BE805D4A,BE805D4B
    01,02,03,04

     

    展开全文
  • 大端存储和小端存储

    2020-11-15 15:06:48
    跨越多字节的程序对象,我们必须建立两个规则:这个对象的地址是什么,以及在内存中如何排列。...第二种规则,从最高有效字节放在最前面的方式称为大端法。 常见的android和IOS系统都是采用小端模式。 ...

    跨越多字节的程序对象,我们必须建立两个规则:这个对象的地址是什么,以及在内存中如何排列。

    某些机器选择在内存中按照从最低有效字节到最高有效字节的顺序存储对象,而另外一些机器按照从最高有效字节到最低有效字节的顺序存储。

    第一种规则,从最低有效字节在最前面的方式称为小端法。

    第二种规则,从最高有效字节放在最前面的方式称为大端法。

    常见的android和IOS系统都是采用小端模式。

    展开全文
  • 大端小段详解—转载

    2019-02-15 17:42:00
    一、大端模式和小端模式的起源 关于大端小端名词的由来,有一个有趣的故事,来自于Jonathan Swift的《格利佛游记》:Lilliput和Blefuscu这两个强国在过去的36个月中一直在苦战。战争的原因:大家都知道,吃鸡蛋的...
  • 大端和小端问题

    2018-03-14 17:19:09
    大端(Big-endian)和小端(Little-endian)是两种存储数据的字节序. 大端: 数据的最高位存储在起始地址单元处, 低位存储在最高地址单元处. 小端: 数据的最低位存储在起始地址单元处, 高位存储在最高地址单元处, ...
  • 大端存储与小端存储

    千次阅读 2018-05-10 17:03:09
    大端存储与小端存储 本文主要以linux下网络编程实验对大端存储与小端存储进行简单讲解: 概念 大端存储与小端存储模式主要指的是数据在计算机中存储的两种字节优先顺序。小端存储指从内存的低地址开始,先存储...
  • 大端模式和小端模式

    万次阅读 多人点赞 2018-08-28 17:09:25
    大端模式(Big-endian):高位字节排放在内存的低地址端,低位字节排放在内存的高地址端,即正序排列,高尾端; 小端模式(Little-endian):低位字节排放在内存的低地址端,高位字节排放在内存的高地址端,即逆序...
  • 大端与小端字节数据详解

    万次阅读 多人点赞 2018-06-10 14:55:03
    计算机是大端数据模式还是小端数据模式对于普通的应用程序没有什么影响,但是在诸如网络编程、芯片寄存器操作的时候就有必要区分一下了,要不然会遇到程序的逻辑设计完全没问题,但得到的数据总是错误的尴尬。...
  • 一、大端模式和小端模式的起源  关于大端小端名词的由来,有一个有趣的故事,来自于Jonathan Swift的《格利佛游记》:Lilliput和Blefuscu这两个强国在过去的36个月中一直在苦战。战争的原因:大家都知道,吃鸡蛋的...
  • 大端模式和小端模式转化

    万次阅读 2015-01-18 12:20:41
    在工作中遇到一个问题,数据是以大端模式存储的,而机器是小端模式,必须进行转换,否则使用时会出问题。 一、定义: 大端模式(Big Endian):数据的高字节,保存在内存的低地址中;数据的低字节,保存在内存的高...
  • 大端 小端

    千次阅读 2017-09-23 09:44:48
    小端模式:指数据的高字节保存在内存的高地址 测试大小 #include int main(void) {  int a = 0x12345678;  unsigned char *p=(unsigned char *)&a;  if(0x78==*p)  {  printf("小端\n"); } else
  • 大端小端格式详解

    万次阅读 多人点赞 2014-07-09 16:30:01
    1. 什么是大端,什么是小端: 所谓的大端模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中; 所谓的小端模式,是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址...
  • 详解大端 小端 (函数判断及转换)

    千次阅读 2013-05-18 12:59:54
     关于大端小端名词的由来,有一个有趣的故事,来自于Jonathan Swift的《格利佛游记》:Lilliput和Blefuscu这两个强国在过去的36个月中一直在苦战。战争的原因:大家都知道,吃鸡蛋的时候,原始的方法是打破鸡蛋
  • ARM存储格式之 大端小端http://blog.csdn.net/asda56/article/details/36919809 我们知道在内存中数据是以字节为单位进行存储的,每个地址单元对应着一个字节(byte),一个字节为8位(bite)。但是很多...
  • 详解大端模式和小端模式

    万次阅读 多人点赞 2011-11-16 20:21:29
    详解大端模式和小端模式 一、大端模式和小端模式的起源  关于大端小端名词的由来,有一个有趣的故事,来自于Jonathan Swift的《格利佛游记》:Lilliput和Blefuscu这两个强国在过去的36个月中一直在苦战。战争的原因...
  • 大端小端详解

    2018-05-08 19:48:51
    2.写一个程序判断当前机器是大端还是小端 代码 #include &amp;amp;amp;amp;amp;lt;stdio.h&amp;amp;amp;amp;amp;gt; #include &amp;amp;amp;amp;amp;lt;stdlib.h&amp;amp;amp;amp;amp;gt; int ...
  • 或许你曾经仔细了解过什么是大端小端,也动手编写了测试手头上的机器上是大端还是小端的程序,甚至还编写了大端小端转换程序;但过了一段时间之后,当你再看到大端小端这两个字眼,你的脑中很快浮起了自己曾经做过...
  • C/C++之大端小端

    千次阅读 2017-03-10 22:21:12
    C/C++之大端小端
  • Linux中判断大端小端

    千次阅读 2015-01-14 10:35:26
    //======================================= 第一个方案 //--------------------------------------------------------- union {  int a;  char b; }EndianTest;...if( EndianTest.b =
  • 大端是指低字节存储在高地址;小端存储是指低字节存储在低地址。我们可以根据联合体来判断该系统是大端还是小端。因为联合体变量总是从低地址存储。 ...
  • c++大端小端判断

    2013-04-17 00:47:04
    大伙觉得这样判断大端小端有问题没? int main() { if (0x78 == (char)0x12345678) printf("little_endian\n"); else printf("big_endian\n"); return 0; }
  • 在嵌入式开发中,经常碰到因序使用不当导致的错误,故决定决定将工作中常见的转序函数进行梳理,一是为了避免犯同样的错误,二是为了以后方便查询。... 小端模式:是指数据的高字节保存在内存的...
  • socket 大端 小端 转换

    千次阅读 2015-01-10 22:20:26
    不同机器内部对变量的字节存储顺序不同,有的采用大端模式(big-endian),有的采用小端模式(little-endian)。 大端模式是指高字节数据存放在低地址处,低字节数据放在高地址处。 小端模式是指低字节数据存放在低...
  • 彻底弄懂计算机中的大端小端

    千次阅读 2015-08-01 10:12:13
    也是必须要掌握的内容,但是很多人就是仅仅是稍微有些了解,但每次真正去做东西的时候,还是要花半天去想,博主就是这样的人,出现这样问题的真正原因是还没有完全弄清楚大端小端。今天就让我们一起彻底的弄懂这两个...
  • PLC中的大端小端

    千次阅读 2019-11-20 08:37:10
    相信大家在阅读有关通讯数据传输、PLC数据存储等技术文档时,经常会碰到“Big-Endian”(大端对齐)与Little-Endian(小端对齐)术语。很多朋友不理解大端小端模式,本文给大家写一下此知识点。 为什么有大端...
  • 判断大端小端

    2018-10-09 15:26:00
    在我们发送数据的时候,我们首先要确定是大端还是小端模式来进行的,在接收方接收的数据必须知道数据是大端还是小端模式,才能正确地读取和存储数据起来,否则就会出错。 一个32位的二进制在内存中的存储时有2中分布...
  • 弄懂大端小端含义

    千次阅读 2018-01-03 15:42:50
    现在先来理解这对概念,大端小端这两个令人迷惑的术语究竟是如何产生的?《程序设计实践》第9章中提到,“大端”和“小端”可以追溯到1726年的Jonathan Swift的《格列佛游记》,其中一篇讲到有两个国家因为吃鸡蛋...
  • 不同处理器体系结构在存储多字节数据时存在大端小端的问题,如下是一个测试处理器大小程序: #include //返回1表示小端,返回0表示大端 int endian() { int i = 0x12345678; char* ch= (char*)(&i); if...
  • 大端小端数据读取

    千次阅读 2017-05-10 15:22:01
    错误原因就是涉及到大端小端数据读取方式的问题,下面就是将这部分内容做一总结。什么是大端小端大小模式就是存储数据时,数据的高低位是怎么存储在地址的高低位上。 大端模式(Most Significant Byte,MSB):...

空空如也

1 2 3 4 5 ... 20
收藏数 32,556
精华内容 13,022
关键字:

大端