如何正确从内存中读取数据(memcpy)

fra*_*ank 1 c c++ memory bit-shift

我有一些表,例如一个声明为 的表uint8_t keyLock[16];,并且我已将这些表的内容保存在我的 MCU 的闪存中。在这个内存中,它看起来像下面这样:

Address    Data
00190008 - BA98B694
0019000C - E854B6E7
00190010 - 9200B2C9
00190014 - 42F8B048
Run Code Online (Sandbox Code Playgroud)

memcpy当我通过函数 ( )将闪存数据复制到表中时,memcpy(keyLock, 0x00190008, 32);表的内容最终就像这样初始化的:

keyLock = {
    0xBA, 0x98, 0xB6, 0x94, 0xE8, 0x54, 0xB6, 0xE7,
    0x92, 0x00, 0xB2, 0xC9, 0x42, 0xF8, 0xB0, 0x48
}
Run Code Online (Sandbox Code Playgroud)

我希望内容就像表是这样初始化的:

keyLock = {
    0x94, 0xB6, 0x98, 0xBA, 0xE7, 0xB6, 0x54, 0xE8,
    0xC9, 0xB2, 0x00, 0x92, 0x48, 0xB0, 0xF8, 0x42
}
Run Code Online (Sandbox Code Playgroud)

我的调用有什么问题memcpy(),我应该如何编写它以在表格中填充所需的内容,如上所示?

Yak*_*ont 6

当您将 4 个字节的内存存储为 32 位整数且值为 时BA98B694,哪个字节先存储?

在您的问题中,您隐含地假设BA字节先行,但在您的系统上,它似乎94先行。

你的memcpy一切都做对了。您的问题是您对字节顺序的期望,或者是闪存中表的布局。

您只需交换每个 4 字节双字的顺序即可修复此问题。

void endian_4byte_swap( uint32_t* bytes ){
  std::swap(bytes[0],bytes[3]);
  std::swap(bytes[1],bytes[2]);
}
void endian_fix_table( uint32_t (&table)[16] ){
  for(int i=0;i<4;++i)
    endian_4byte_swap(&table[4*i]);
}
Run Code Online (Sandbox Code Playgroud)

但这只能解决症状而不是疾病。真正的解决方法是在闪存中修复表,假设您可以控制它。