架构ARM9.编程语言C.
我们有一个第三方堆栈,其中一个调用将一个指针(pBuffer
)带到一个内存位置.在堆栈中,它们可以自由地移动指针传递并按照自己的意愿访问它.不幸的是,它们偏移了传入的指针并将其传递给另一个试图从奇数/未计数内存位置执行此操作的函数
((uint16 *)pBuffer)[index] = value;
where value
是类型,uint16
并index
检查边界和索引pBuffer
.这会导致未对齐的内存访问异常.pBuffer
指向char *
堆上.
如上所述,即使我们可以查看第三方堆栈,我们也无法正式更新代码.因此,我们通知提供商,他们在下一版本中提供更新.
我想知道是否有解决方法.如何在不违反未对齐访问的情况下执行上述分配?解决此类问题的最佳方法是什么?
逐字节复制值.将其转换为(无符号)char指针,然后一次复制一个字节.
它不漂亮,但听起来并不像你有很多选择.