gpt4 book ai didi

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

转载 作者:太空宇宙 更新时间:2023-11-04 06:19:25 29 4
gpt4 key购买 nike

我有一些表,例如声明为 uint8_t keyLock[16]; 的表,我已将这些表的内容保存在我的 MCU 的闪存中。在此内存中,它如下所示:

Address    Data
00190008 - BA98B694
0019000C - E854B6E7
00190010 - 9200B2C9
00190014 - 42F8B048

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

keyLock = {
0xBA, 0x98, 0xB6, 0x94, 0xE8, 0x54, 0xB6, 0xE7,
0x92, 0x00, 0xB2, 0xC9, 0x42, 0xF8, 0xB0, 0x48
}

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

keyLock = {
0x94, 0xB6, 0x98, 0xBA, 0xE7, 0xB6, 0x54, 0xE8,
0xC9, 0xB2, 0x00, 0x92, 0x48, 0xB0, 0xF8, 0x42
}

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

最佳答案

当您将 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]);
}

但这只能治标不治本。真正的解决方法是在闪存中修复表格,前提是您可以控制它。

关于c++ - 如何从内存中正确读取数据(memcpy),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38467523/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com