zoukankan      html  css  js  c++  java
  • 字节序与大小端

    为什么会有字节序问题

    1. 内存以8bit为一个地址单位:早期的处理器地址以8bit为一个单位(8位处理器),也就是说一次可以访问8bit的数据,后来出现了16位,32位甚至64位的处理器,但为了兼容最早的8位处理器,因此沿用8bit为一个地址单位。

    2. 大于8位的处理器,如32位处理器,虽然每个8bit(一个字节)存储数据的方式是一样的,但是针对整形这样的有多个字节的数据结构的数据,每个字节内存储数据方式相同,但字节间(即几个字节的顺序)存储方式不同。

    3.其他历史原因.


    不同的处理器结构对整形这样的大数据类型的每个字节在内存中存放顺序不一样,这样,在不同架构的处理器平台进行通讯时,就产生了字节序的问题。

    不同处理器的通讯一般通过网络通信进行,于是我们统一了网络字节序(使用大端字节序)。


    关键点:

    字节序:  大整形数据类型(如int,short,而char就不算了)的数据中各个字节在内存的存储书序。

    一般在网络通信是需要关注。


    大端与小端

    字节序有两种,大端和小端

    大端:数据高位存放在低地址,地位放在高地址。如0x12345678在内存中存放为   12 34 56 78 (地址,从左到右为低到高)

    小端:数据地位存放在低地址,高位存放在高地址。如0x12345678在内存中存放为 78 56 34 12 (地址,从左到右为低到高)


    下面列举几种大小端的平台



    字节序转换的几个函数:

    <pre name="code" class="cpp">#include <arpa/inet.h>
    uint32_t htonl(uint32_thostint32);
    				Returns: 32-bit integer in network byte order
    uint16_t htons(uint16_thostint16);
    				Returns: 16-bit integer in network byte order
    uint32_t ntohl(uint32_tnetint32);
    				Returns: 32-bit integer in host byte order
    uint16_t ntohs(uint16_tnetint16);
    				Returns: 16-bit integer in host byte order


    
    

    16表示16bit,short占16位。 32表示32位,unsigned int 占32位。

    h表示host, n表示network。 l表示long, s表示short

    在网络通信中,一般只有地址和端口号需要进行字节序的转换,因为其他数据以字符串进行传送。

    为什么会有字节序问题

    1. 内存以8bit为一个地址单位:早期的处理器地址以8bit为一个单位(8位处理器),也就是说一次可以访问8bit的数据,后来出现了16位,32位甚至64位的处理器,但为了兼容最早的8位处理器,因此沿用8bit为一个地址单位。

    2. 大于8位的处理器,如32位处理器,虽然每个8bit(一个字节)存储数据的方式是一样的,但是针对整形这样的有多个字节的数据结构的数据,每个字节内存储数据方式相同,但字节间(即几个字节的顺序)存储方式不同。

    3.其他历史原因.

    不同的处理器结构对整形这样的大数据类型的每个字节在内存中存放顺序不一样,这样,在不同架构的处理器平台进行通讯时,就产生了字节序的问题。

    不同处理器的通讯一般通过网络通信进行,于是我们统一了网络字节序(使用大端字节序)。

    关键点:

    字节序:  大整形数据类型(如int,short,而char就不算了)的数据中各个字节在内存的存储书序。

    一般在网络通信是需要关注。

    大端与小端

    字节序有两种,大端和小端

    大端:数据高位存放在低地址,地位放在高地址。如0x12345678在内存中存放为   12 34 56 78 (地址,从左到右为低到高)

    小端:数据地位存放在低地址,高位存放在高地址。如0x12345678在内存中存放为 78 56 34 12 (地址,从左到右为低到高)

    下面列举几种大小端的平台

    字节序转换的几个函数:

    <pre name="code" class="cpp">#include <arpa/inet.h>
    uint32_t htonl(uint32_thostint32);
    				Returns: 32-bit integer in network byte order
    uint16_t htons(uint16_thostint16);
    				Returns: 16-bit integer in network byte order
    uint32_t ntohl(uint32_tnetint32);
    				Returns: 32-bit integer in host byte order
    uint16_t ntohs(uint16_tnetint16);
    				Returns: 16-bit integer in host byte order


    
    

    16表示16bit,short占16位。 32表示32位,unsigned int 占32位。

    h表示host, n表示network。 l表示long, s表示short



    在网络通信中,一般只有地址和端口号需要进行字节序的转换,因为其他数据以字符串进行传送。






  • 相关阅读:
    HDU 1873 看病要排队(结构体+优先队列)
    优先队列
    栈和队列
    Light OJ 1214 Large Division (大数取模)
    LightOJ 1078 Integer Divisibility (同余定理)
    51nod 1513-3的幂的和(费马小定理+快速幂)
    51nod 1256 乘法逆元(扩展欧几里得)
    格式测试
    点Point 圆Circle 圆柱Cylinder的继承与派生
    JUC 并发编程--04 常用的辅助类CountDownLatch , CyclicBarrier , Semaphore , 读写锁 , 阻塞队列,CompletableFuture(异步回调)
  • 原文地址:https://www.cnblogs.com/Windeal/p/4284610.html
Copyright © 2011-2022 走看看