*(uint32_t *)p = g_array_index(c->common_caps, uint32_t, i);
warning: cast increases required alignment of target type [-Wcast-align]
Android平台,C/C++代码内存对齐问题(signal SIGBUS Error)
最近手机版本老出现崩溃,之前出现过,但很偶然。最近出现机率比较高,就跟查一下。
报了signal SIGBUS BUS Error,最终定位在uint32_t i32 = *((uint32_t*)m_data); 这句语出了问题, 确认m_data内存是正确的,并且在PC机上运行是正常的。
后面查到原因是x86架构CPU是支持内存非对齐访问,而手机的CPU采用的是RISC架构,为了提高访问效率,不支持非对齐访问。
也就是说将内存m_data转成无符号整形unit32_t,内存地址需要是4的整数倍。
将uint32_t i32 = *((uint32_t*)m_data)改为
uint32_t i32 = 0;
char* p = (char*)&i32;
for(int i =0;i < 4;i++)
{
p[i] = m_data[i];
报了signal SIGBUS BUS Error,最终定位在uint32_t i32 = *((uint32_t*)m_data); 这句语出了问题, 确认m_data内存是正确的,并且在PC机上运行是正常的。
后面查到原因是x86架构CPU是支持内存非对齐访问,而手机的CPU采用的是RISC架构,为了提高访问效率,不支持非对齐访问。
也就是说将内存m_data转成无符号整形unit32_t,内存地址需要是4的整数倍。
将uint32_t i32 = *((uint32_t*)m_data)改为
uint32_t i32 = 0;
char* p = (char*)&i32;
for(int i =0;i < 4;i++)
{
p[i] = m_data[i];
}
GNU Linux Sparc Porting
https://wiki.openoffice.org/wiki/GNU_Linux_Sparc_Porting https://issues.apache.org/ooo/show_bug.cgi?id=65788
本文深入探讨了在Android平台上使用C/C++代码时遇到的内存对齐问题,特别是与SIGBUS错误相关联的问题。通过分析导致信号SIGBUS的原因,解释了x86架构与RISC架构CPU之间的差异,特别是内存访问的对齐要求。文章提供了一个具体的代码示例,展示了如何在不同架构下正确处理内存对齐,避免SIGBUS错误的出现。同时,提供了GNU Linux Sparc Porting的相关链接,帮助开发者更好地理解跨平台开发中的内存对齐挑战。
1万+

被折叠的 条评论
为什么被折叠?



