• 大小端存储模式的理解和判断


    在计算机系统中,存储是以字节为单位的,每个地址单元都对应着一个字节,一个字节=8bit。在C语言中除了8bitchar之外,还有16bitshort型,32bitlong型(要看具体的编译器)。对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,如何安排多个字节的存储,这就有了大端存储模式和小端存储模式。

    小端:较高的有效字节存放在较高的的存储器地址,较低的有效字节存放在较低的存储器地址。 大端:较高的有效字节存放在较低的存储器地址,较低的有效字节存放在较高的存储器地址。 如果将一个16位的整数0x1234存放到一个短整型变量(short)中。这个短整型变量在内存中的存储在大小端模式由下表所示。

    地址偏移

    大端模式

    小端模式

    0x00

    12OP0

    34OP1

    0x01

    34OP1

    12OP0

    小端模式:强制转换数据不需要调整字节内容,124字节的存储方式一样。

    大端模式:符号位的判定固定为第一个字节,容易判断正负。

    常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARMDSP都为小端模式。

    什么时候要进行大小端字节序的转换?  

    short 或者 long的数据在进行通信的时候最好养成:  1、发送的时候使用:htonsl 2、接受的时候使用:ntohsl 而不要理会两边的通信是否需要这么做~~  当然了一般我都不用int型的数据通信,从来都是字符串通信,发送方利用sprintf组织,接收方利用atoi进行转换~~

    C语言判断大小端模式

    方法一:

    void IsBigEndian()
    {
     short int a = 0x1122;//十六进制,一个数值占4位
     char b =  *(char *)&a;  //通过将short(2字节)强制类型转换成char单字节,b指向a的起始字节(低字节)
     if( b == 0x11)//低字节存的是数据的高字节数据
     {
      //是大端模式
     }
     else
     {
      //是小端模式
     }
    }

    方法二:

    void IsBigEndian()//原理:联合体union的存放顺序是所有成员都从低地址开始存放,而且所有成员共享存储空间
    {
     union temp
     {
      short int a;
      char b;
     }temp;
     temp.a = 0x1234;
     if( temp.b == 0x12 )//低字节存的是数据的高字节数据
     {
      //是大端模式
     }
     else
     {
      //是小端模式
     }
    }
  • 相关阅读:
    Nginx出现413 Request Entity Too Large错误解决方法
    Apache设置二级域名和虚拟主机
    LNMP搭建03 -- 编译安装PHP
    LNMP搭建04 -- 配置Nginx支持PHP
    LNMP搭建01 -- 编译安装MySQL 5.6.14 和 LNMP相关的区别
    LNMP搭建02 -- 编译安装Nginx
    vagrant使用小结
    LeetCode Count and Say
    基于ArcGIS Flex API实现动态标绘(1.0)
    HDU 2027 汉字统计
  • 原文地址:https://www.cnblogs.com/yangyuxiaozi/p/5322348.html
Copyright © 2020-2023  润新知