大端模式与小端模式

概念:

大小端模式是指各种体系的计算机系统(CPU的体系架构:PPC、ARM、MIPS等)中采用的字节存储机制(多字节数据类型),分为:大端模式和小端模式两种。


大端模式:是指数据的高字节保存在内存的低地址中,数据的低字节保存在内存的高地址中。

小端模式:是指数据的高字节保存在内存的高地址中,数据的低字节保存在内存的低地址中。


主机序:不同的CPU有不同的字节序类型,这些字节序是指整数在内存中的保存顺序,这个叫主机序。

网络序:是TCP/IP中规定好的一种数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能被正确                 的解释,网络序采用大端模式


大小端模式下数据在内存中的存储情况:

以数据 0x12345678 为例:


大端模式下数据在内存中的分布为:

地址0123
数据0x120x340x560x78

    数据的高字节保存在内存的低地址中,数据的低字节保存在内存的高地址中


小端模式下数据在内存中的分布为: 

地址0123
数据0x780x560x340x12
             数据的高字节保存在内存的高地址中,数据的低字节保存在内存的低地址中



一个小端系统的验证例子:

// BigOrLittle.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <stdio.h>
#include "typedef.h"

int _tmain(int argc, _TCHAR* argv[])
{
      UINT32 uiValue = 0x12345678;
      UCHAR  aucBuffer[4] = {0};

      aucBuffer[0] = ((UCHAR*)&uiValue)[0];
      aucBuffer[1] = ((UCHAR*)&uiValue)[1];
      aucBuffer[2] = ((UCHAR*)&uiValue)[2];
      aucBuffer[3] = ((UCHAR*)&uiValue)[3];

      printf("Little endian data: %x  %x  %x  %x",aucBuffer[0], aucBuffer[1], aucBuffer[2], aucBuffer[3]);

      getchar();

      return 0;
}

         结果:




大小端的检测方法:

下面这段代码可以用来测试你的编译器是大端模式还是小端模式:

// BigOrLittle.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <stdio.h>
#include "typedef.h"

typedef union tagBigOrLittleData
{
	UINT32    uiA;
	UCHAR     ucB;
	UCHAR     ucC;
	UCHAR     ucD;
	UCHAR     ucE;

}BigOrLittleData_U;

UINT32 CheckCPUendian()
{
	BigOrLittleData_U  Data;

	Data.uiA = 0x1;

	return (1 == Data.ucB); /*0 表示大端  1表示小端*/
}

int _tmain(int argc, _TCHAR* argv[])
{
	UINT32 uiCheckFlag = 0;

	uiCheckFlag = CheckCPUendian();

	if (uiCheckFlag)
	{
		printf("result: Little endian.");
	} 
	else
	{
		printf("result: Big endian.");
	}

	getchar();

	return 0;
}

大小端的转换方法:


#define Big2Little_32(x)  ((((x)&0x000000ff)<<24)| \
	                       (((x)&0x0000ff00)<<8) | \
						   (((x)&0x00ff0000)>>8) | \
						   (((x)&0xff000000)>>24))

#define Big2Little_16(x)  ((((x)&0x00ff)<<8) | \
	                       (((x)&0xff00)>>8))


#define Big2Little_64(x)  ((((UINT64)(Big2Little_32((UINT32)(x))))<<32) | \
	                       (Big2Little_32((UINT32)(((UINT64)(x))>>32))))




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值