我需要在 C 中将两个UCHAR
(8 位)数组组合成一个USHORT
(16 位)值。但我必须在不使用“for”或任何循环的情况下这样做。
作为:
UCHAR A[1000], B[1000];
USHORT C[1000];
结果必须为:
C[0] = {A[0], B[0]};
C[1] = {A[1], B[1]};
...
C[1000]={A[1000], B[1000]};
uint8_t one = 0xBA;
uint8_t two = 0xBE;
uint16_t both = one << 8 | two;
更新: 也许我还没有理解你的问题......但是如果你想将一个 uint8_t 数组转换为一个 uint16_t 数组-> 检查大小并强制转换
uint8_t array[100];
uint16_t array_ptr_ushort* =(uint16_t*)&array[0];
确保数组的大小是均匀的。
更新2:
uint8_t array1[100];
uint8_t array2[100];
uint16_t combined[100];
memcpy(combined, array1, sizeof(array1))
memcpy((uint8_t*)combined + sizeof(array1), array2, sizeof(array2))
更新3:
您不能在没有某种循环的情况下将两个数组组合在一个连续数组中,即使您为此使用 DMA,循环也会存在于底层硬件中......
更新4:
您可以递归地执行此操作。
#include "stdafx.h"
#include <cstdint>
#include <algorithm>
uint8_t arrayA[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
uint8_t arrayB[] = {0xA, 0x9, 0x8, 0x7, 0x6, 0x5, 0x4, 0x3, 0x2, 0x1};
uint16_t array_combined[sizeof(arrayA)] = {};
static_assert(sizeof(arrayA) == sizeof(arrayB), "Arrays of different sizes");
uint16_t combine(const uint8_t *a, const uint8_t *b, uint16_t *put, uint32_t size)
{
uint16_t value = (*a << 8) | *b;
if(size)
*put = combine(++a, ++b, ++put, --size);
return value;
}
void combine_arrays(const uint8_t *a, const uint8_t *b, uint16_t *put, uint32_t size)
{
*put = combine(a, b, put, size);
}
int _tmain(int argc, _TCHAR* argv[])
{
combine_arrays(arrayA, arrayB, array_combined, sizeof(arrayA));
return 0;
}
UPDATE5:带有来自 C++ 的 static_assert 的 C 版本
#include <stdint.h>
uint8_t array1[] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
uint8_t array2[] = {0xA, 0x9, 0x8, 0x7, 0x6, 0x5, 0x4, 0x3, 0x2, 0x1};
uint16_t array_combined[sizeof(array1)] = {};
static_assert(sizeof(array1) == sizeof(array2), "Arrays of different sizes");
int _tmain(int argc, _TCHAR* argv[])
{
int size = sizeof(array1);
int count = 0;
do
{
array_combined[count] = (array2[count] << 8) | array1[count];
}while(count++ != size);
return 0;
}
UPDATE6:也有 C++ 方法来实现这一点......
ushortVal = ( ucharVal[0] << 8 ) | ucharVal[1];
对于单个元素,您可以将第一个字节按位向左移动 8 位,然后使用按位或添加第二个字节:
C[i] = (A[i] << 8) | B[i];
但是对于数组,您基本上想将两个数组“分散”到第三个数组中,如下所示:
A[0] B[0] | A[1] B[1] | A[2] B[2] | ... | A[n-1] B[n-1]
C[0] | C[1] | C[2] | ... | C[n-1]
这意味着如果数组的第一个元素C
存储在地址0
,则数组中的元素A
应位于地址 0、16、32、48...,而数组中的元素应B
位于地址 8、24...恕我直言,不使用任何循环就无法完成