如何正确地从内存中读取数据(memcpy)
How to properly read data from memory (memcpy)
我有一些表,例如一个声明为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个字节的内存存储为值为BA98B694
的32但整数时,哪个字节先存储?
在您的问题中,您隐含地假设BA
字节位于第一位,但在您的系统中,似乎94
位于第一位。
你的memcpy
做得很好。你的问题是你对endianness的期望,或者你的表在flash中的布局。
您可以通过简单地交换每个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]);
}
但这能解决症状而不是疾病。真正的修复方法是在flash中修复表,假设您可以控制它。
相关文章:
- 防止主数据类型C++的隐式转换
- 用于访问容器<T>数据成员的正确 API
- 嵌套在类中时无法设置成员数据
- 使用流处理接收到的数据
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 使用 memcpy 将矢量数据复制到 wstring 的正确方法
- 对于单个数据 WORD 的 memcpy 和赋值语句有什么区别?
- 直接向工会而不是其特定成员之一发送memcpy数据是否安全
- memcpy是否可以保留不同类型之间的数据
- 套接字:在没有memcpy的情况下,使用recvfrom将UDP数据获取到字对齐的缓冲区
- 非初始化的数据和memcpy
- 使用memcpy将数据复制到结构的成员,并给出指向结构的双指针
- 如何使用 memcpy 将数据从两个整数复制到字符数组
- 为什么memcpy无法复制特征矩阵数据,但std::复制成功
- 将内置数据类型转换为std::string: memcpy vs snprintf
- 使用memcpy将多个数据复制到char*中
- 普通旧数据和“std::memcpy”对齐问题
- 使用任何缓冲区来存储任何数据,放置位置为new和memcpy
- 如何正确地从内存中读取数据(memcpy)
- memcpy() 可以用来更改"const"成员数据吗?