是否可以在一条指令中将4uint8_t复制到4int16中

Is it possible to copy 4 uint8_t into 4 int16 in one instruction?

本文关键字:复制 4int16 4uint8 一条 指令 是否      更新时间:2023-10-16

我想知道是否可以尽快将存储在一个uint32_t中的四个uint8_t值复制到uint64_t中的适当位置。我正在寻找等价物:

union
{
  struct {uint8_t a; uint8_t b; uint8_t c; uint8_t d};
  uint32_t whole;
} x32;
 union
{
  struct {int16_t a; int16_t b; int16_t c; int16_t d};
  uint64_t whole;
} x64;
x64.a=x32.a;
x64.b=x32.b;
x64.c=x32.c;
x64.d=x32.d;

问题是:我无法使用MMX/SSE。

否。没有其他方法可以像现在这样移动数据并对其进行零扩展

C++标准中不支持通过并集的类型punning。相反,使用ors和shift将值组合在一起。正确性比快速但坏掉的代码更重要。

uint8_t a,b,c,d;
uint64_t whole;
whole = a | (uint64_t (b) << 1*16) | (uint64_t (c) << 2*16) | (uint64_t (d) << 3*16)

不,这是不可能的,因为硬件几乎不会提供这样(非常具体)的汇编指令。