C/C++ 大小端理解及转换

         在开发过程中,遇到了大小端的问题,我们用的X86结构是小端模式,KeilC51为大端模式,ARM和DSP很多为小端模式,

         引用百度百科的大小端解释:

        大端模式(Big-endian),是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;这和我们的阅读习惯一致。

        小端模式(Little-endian),是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低。

        在此先推出一个测试网站:http://tool.oschina.net/hexconvert/

C/C++ 大小端理解及转换_第1张图片

之后介绍一个byte转int的C/C++ 源码

小端模式

//byte转int  
long int bytes4ToInt(byte* bytes)
{
	long int addr = bytes[0] & 0xFF;
	addr |= (bytes[1] << 8 & 0xFF00);
	addr |= ((bytes[2] << 16) & 0xFF0000);
	addr |= ((bytes[3] << 24) & 0xFF000000);
	return addr;
}

大端模式

//byte转int  
long int bytes4ToInt(byte* bytes)
{
	long int addr = bytes[3] & 0xFF;
	addr |= (bytes[2] << 8 & 0xFF00);
	addr |= ((bytes[1] << 16) & 0xFF0000);
	addr |= ((bytes[0] << 24) & 0xFF000000);
	return addr;
}


你可能感兴趣的:(C++编程)