大端小端转换

大小端转换方法:

#include<stdlib.h>

#include<stdio.h>

#define Tranverse16(X)                 ((((UINT16)(X) & 0xff00) >> 8) |(((UINT16)(X) & 0x00ff) << 8))
#define Tranverse32(X)                 ((((UInt32)(X) & 0xff000000) >> 24) | /
                                                           (((UInt32)(X) & 0x00ff0000) >> 8) | /
                                                           (((UInt32)(X) & 0x0000ff00) << 8) | /
                                                           (((UInt32)(X) & 0x000000ff) << 24))

void main()
{


 //测试本地是大端还是小端

//取出一个四字节的最低一个字节,若取出的最低位与原来整数的最低位一致,说明是小端

  int i = 1;

 //if (*(char*)&i==1)

//{
 // printf("小端");

//}

 //else

//{

    printf("大端");

//}
 UINT16 data = Tranverse16(256);//data =1
 UINT32 data1 = Tranverse16(1);// data1 = 256

}

在字符串中,大端小端是无意义的。大端小端只涉及到多字节数据类型(如整数、浮点数)在内存中的存储方式。在内存中,多字节数据类型的存储方式有两种:大端字节序和小端字节序。 如果你要转换多字节数据类型的字节序,你需要将其转换为字节数组,然后对字节数组进行操作。具体的转换方法如下: 1. 将多字节数据类型转换成字节数组。 2. 判断当前系统是大端字节序还是小端字节序。 3. 如果当前系统是大端字节序,则将字节数组倒序排列。 4. 如果当前系统是小端字节序,则不需要进行任何操作。 5. 将字节数组转换回多字节数据类型。 以下是一个示例代码,演示了如何将大端字节序转换小端字节序: ```c++ #include <cstdint> #include <cstring> void swapEndian(uint8_t* data, size_t size) { for (size_t i = 0; i < size / 2; i++) { uint8_t temp = data[i]; data[i] = data[size - i - 1]; data[size - i - 1] = temp; } } void toLittleEndian(uint8_t* data, size_t size) { if (*(uint16_t*)"\x01\x02" == 0x0201) { swapEndian(data, size); } } int main() { uint16_t value = 0x1234; uint8_t bytes[sizeof(value)]; std::memcpy(bytes, &value, sizeof(value)); toLittleEndian(bytes, sizeof(bytes)); uint16_t result; std::memcpy(&result, bytes, sizeof(result)); return 0; } ``` 在本例中,我们将一个16位整数值转换为字节数组,然后将字节数组转换小端字节序,最后将字节数组转换回整数值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值