背景
// gSysConfigReg 为 SysConfigRegBytes 长度的 uint8_t 数组。
uint8_t gSysConfigReg[SysConfigRegBytes];
方式
// 通过指针方式将 gSysConfigReg[i] 地址的数据以 uint16_t 的形式读出,
// 赋值给 uint16Data.
uint16Data = *((uint16_t*)(&gSysConfigReg[i]));
解读
&gSysConfigReg[i]
:获取 gSysConfigReg[i] 的地址。实际,内存中创建了临时指针,指针对应的是 gSysConfigReg[i] 的地址,指令类型与 gSysConfigReg 类型相同,均为 uint8_t。(uint16_t*)(&gSysConfigReg[i])
:强制转换为 uint16_t 类型的指针。*((uint16_t*)(&gSysConfigReg[i]))
:访问 uint16_t 指针所指向地址的内容。- 这样,就可以不用偏移就可以获取到 uint16_t 的数据了。
// 老套做法: 移位 + 或运算
uint16Data = gSysConfigReg[i] | (gSysConfigReg[i + 1] << 8);
注意事项
- uint8_t 的内存地址为:0,1, 2, 3,4,5 …
- uint16_t 的内存地址为:0, 2, 4,6…
这就意味着,当 uint16_t 的地址为不可能为单数,若为单数,程序直接就会跑飞了。