大端模式和小端模式

 不同的系统在存储数据时是分大端(bit-endian)小端(little-endian)存储的,比如,Inter x86、ARM核采用的是小端模式,Power PC、MIPS UNIX和HP-PA UNIX采用大端模式

小端模式用文字描述是,低地址上存放低字节,高地址上存放高字节。

假如有一个32位的数据 0x11223344,则在小端模式上的机器上存储为如下的形式:

【1】0x11223344这个数中 0x11 是高字节(MSB),0x44是地字节(LSB)

【2】讨论大小端的时候最小单位是字节

【3】内存的画法中采用的是向上增长的

【3】可以将数据比作方向盘,顺时钟旋转得到的在内存中的布局是小端存储

 

至于大端模式用文字描述是,低地址上存放高字节,高地址上存放低字节。

 

 如何判断


判断的方法有很多种,下面将简单的列举几种:

第一种方法:

/*
* 1: little-endian
* 0: big-endian
*/
int checkEndian()
{
    int a = 1;
    char *p = (char *)&a;
    return (*p == 1);
}

【1】如果是大端,*p的结果是0

第二种方法:

/*
* 1: little-endian
* 0: big-endian
*/
int checkEndian()
{
    union w
    {
        int a;
        char b;
    } c;
    c.a = 1;
    return (c.b == 1);
}

大端和小端的转换

int big_litle_endian(int x)
{
    int tmp;
    tmp = (((x)&0xff)<<24) + (((x>>8)&0xff)<<16) + (((x>>16)&0xff)<<8) + (((x>>24)&0xff));
    return tmp;
}

4. 其他


 

1. 在通信的场合经常会遇到大端和小端的转换的问题,比如tcp/ip 中,tcp/ip 中规定了自己传输的时候采用大端模式,当然相应的它也提供了很多函数来做支持。

如果主机是小端的模式,在跟网络进行交互的时候经常要用到如下的函数

  • htons —— 把unsigned short类型从 主机序 转成 网络字节序
  • ntohl —— 把unsigned long类型从 网络字节序 转成 主机序
  • ntohs —— 把unsigned short类型从 网络字节序 转成 主机序
  • htonl —— 把unsigned long类型从 主机序 转成 网络字节序
需要包含头文件:
#if defined(_LINUX) || defined(_DARWIN)
 
#include <netinet/in.h>
 
#endif
 
#ifdef WIN32
 
#include <WINSOCK2.H>
 
#endif 

当一个系统要发送的数据是 0x12345678,以大端模式发送,则会先发送0x12.

 

2. 如何在64位ubuntu下同下编译32位的程序?

需要先安装32位的库:sudo apt-get install libc6-dev-i386

然后在编译的时候加上-m32选项。

转载于:https://www.cnblogs.com/GHzz/p/9322192.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值