访问数组的奇数索引时 C 中的位移位错误

Error with Bit Shifting in C while Accessing Odd Index of Array

我目前正在通过蓝牙向 C 程序发送一组无符号的 8 位整数(作为特征)。收到这个数据包后,我想取一对索引和 "concatenate" 它们的编号,如下所示:

Input: [0xDE, 0xAD, 
        0xDE, 0xAD, 
        0xBE, 0xEF]

Output: [0xDEAD, 0xDEAD, 0xBEEF]

但是,我 运行 遇到了一个奇怪的问题。当我输出到偶数索引时我的代码工作正常(获取数组的前两个元素并连接它们),但当我输出到奇数元素时失败(例如,尝试连接元素 3 和 4(0xDE 和 0xAD) .

所以,我从程序中得到的输出是这样的:

Input: [0xDE, 0xAD, 
        0xDE, 0xAD, 
        0xBE, 0xEF]

Output: [0xDEAD, 0xADDE, 0xBEEF]

这是我的代码:

  for(int i = 0; i < numUUID; i++)
  {
      // The i+1 and i+2 are because the first value of the array contains
      // a byte on how many UUIDs are incoming
      uuidFilter[i] = (incoming[i + 1] << 8) | incoming[i + 2];
  }

您正在处理来自传入数组的 2 个元素,但仅将 i 递增 1。因此您正在处理
incoming[i_1] and incoming[i_2]
incoming[i_2] and incoming[i_3]

但看起来你应该将 i 递增 2,这会给你
incoming[i_1] and incoming[i_2]
incoming[i_3] and incoming[i_4]

您还必须在 i=1 处开始循环以跳过第一个字节。

假设您的输入是这样的:

[numUUID, 0xDE, 0xAD, 0xDE, 0xAD, 0xBE, 0xEF]

您的高字节位于索引 1、3 和 5,而低字节位于索引 2、4 和 6。请注意它们是成对出现的。这意味着当您对数组进行索引时,您应该在某处有一个 2*i ,这样您就可以在每个增量上逐步进行两次。答案如下:

for(int i = 0; i < numUUID; i++)
{
    uuidFilter[i] = (incoming[2*i + 1] << 8) | incoming[2*i + 2];
}

这是假设 numUUID 是您要连接的 的数量。如果是字节数,那当然要在循环条件中除以2。