高低位转换

本文讲述了在读取串口数据时遇到的数值问题,通过将489976332转换为16进制发现与目标值208811037存在联系,揭示了数据传输中的高低位转换技巧,通过`reverseHex`函数实现实例操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

读一写串口数据的时候,可能读到的值并不是你想要的,但是却和想要的,有某种联系

例如从SDK读到了一个数据 489976332,而我需要的确实 208811037;这两个数有什么关系呢;

先转换成16进制,突然发现

在这里插入图片描述看起来毫不相干的两个数,存在某种联系

这个就是数据传输中,经常需要用到的高低位转换

@Test
public void test_reverseHex() {
  Assert.assertEquals("23010A2E", reverseHex("2E0A0123"));
  Assert.assertEquals("2E0A0123", reverseHex(reverseHex("2E0A0123")));
}
private static String reverseHex(final String hex) {
  final char[] charArray = hex.toCharArray();
  final int length = charArray.length;
  final int times = length / 2;
  for (int c1i = 0; c1i < times; c1i += 2) {
    final int c2i = c1i + 1;
    final char c1 = charArray[c1i];
    final char c2 = charArray[c2i];
    final int c3i = length - c1i - 2;
    final int c4i = length - c1i - 1;
    charArray[c1i] = charArray[c3i];
    charArray[c2i] = charArray[c4i];
    charArray[c3i] = c1;
    charArray[c4i] = c2;
  }
  return new String(charArray);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值