序言:当同一台主机上的两个进程(一个由c语言编写,另一个由Java编写)通信或者两台使用不同字节序的主机之间传送数据时,若字节序不同,则发送的数据和接受的数据不一样。因此需要进行小端字节序(小端模式)、大端字节序(大端模式)的识别与转换。以下以32位机器讲解。
大端字节序(也称 大端模式):指一个整数的高位字节(23~31bit)存储在内存的低地址处,低字节(0 ~ 7bit)存储在内存的高地址处。
小段字节序(小端模式):指一个整数的高位字节存储在 内存 的高地址处,低字节存储在内存的低地址处。
- 数据的高字节和低字节理解如下
- 数据在内存中的存储有大端字节序和小端字节序,分别如下所示:
小端模式:
大端模式:
以下使用C++代码进行检测 计算机 采用的是大端模式还是小端模式。
#include <iostream>
void ByteOrderTest()
{
union // 结构体变量共用相同内存地址
{
short value;
char union_bytes[sizeof(short)];
}test;
test.value = 0x0102;
if ((test.union_bytes[0] == 1) && (test.union_bytes[1] == 2))
std::cout << "big_endian" << std::endl;
else if((test.union_bytes[0] == 2) && (test.union_bytes[1] == 1))
std::cout << "smal_endian" << std::endl;
else
std::cout << "unknown ..." << std::endl;
}
int main()
{
ByteOrderTest();
}