大端和小端
在计算机科学中,程序大端和小端是指程序在内存中的存储方式。具体来说,大端和小端是指变量的起始地址和结束地址在内存中的位置关系。
在大端存储方式下,变量的起始地址和结束地址之间的距离是不固定的,变量的大小以字节为单位,从高位到低位依次存储。这种存储方式通常在早期的计算机中使用,如IBM-PC系列计算机和DEC VAX-11系列计算机。
在小端存储方式下,变量的起始地址和结束地址之间的距离是固定的,变量的大小以字节为单位,从低位到高位依次存储。这种存储方式通常在现代计算机中使用,如x86架构的计算机和ARM架构的计算机。
在进行数据传输时,大端和小端的存储方式会影响数据的传输顺序。如果两个程序使用的是不同的存储方式,就需要进行数据转换,以保证数据的正确传输。
大小端测试
测试大小端一般使用union的特性。union是一个联合体,所有变量公用一块内存,只是在不同的时候解释不同。其在内存中存储是按最长的那个变量所需要的位数来开辟内存的。
//============================================================================
// Name : Test.cpp
// Author : Lin
// Version :
// Copyright : Your copyright notice
// Description : Hello World in C++, Ansi-style
//============================================================================
#include <stdio.h>
#include <string.h>
#include <iostream>
using namespace std;
union {
int num;
char cV;
}TestEndian;
bool TestBigEndian()
{
TestEndian.num = 0x01000002;
return (TestEndian.cV == 0x01);
}
int main()
{
if (TestBigEndian())
printf("Big Endian");
else
printf("Small Engian");
return 0;
}
大小端数据转换
// 实现16bit的数据之间的大小端转换
#define EDION_SWITCH_16(V) ((((uint16)(V) & 0xff00 ) >> 8) | \
(((uint16)(V) & 0x00ff ) << 8))
// 实现32bit的数据之间的大小端转换
#define EDION_SWITCH_32(V) ((((uint32)(V) & 0xff000000) >> 24) |\
(((uint32)(V) & 0x00ff0000) >> 8) | \
(((unit32)(V) & 0x0000ff00) << 8) | \
(((uint32)(V) & 0x000000ff) << 32) )