几年前,调试过一个加密解密算法程序,原来这个程序是在Windows和Linux平台可以顺利编译并运行;我把程序移植到了嵌入式的ArcLinux上,程序可以顺利编译,唯独运行的时候,每次都在地址转换的时候程序崩溃。程序大概如下:
1: void func_special(uint8 * pData, const int DataLen)
2: {
3: int Len = DataLen / 4;
4: unsigned int * pS = (unsigned int *)pData;//ERROR.Lead to crash
5: for (int i =0; i < Len; i ++)
6: {
7: pS[i] ...
8: }
每次都是在line 4处Crash,最开始的时候不知道为什么,后来查阅资料发现,ArcLinux上对不同的数据类型,采用的内存地址是有不同对齐方式的,譬如: uint8 *这种是采用4字节对齐的地址,而unsigned int*这种类型则是8字节对齐的地址。如果强制把一个非8字节对齐的uint8*的地址转换为unsigned int*,这将导致系统内存检测失败,直接crash。
因此,在嵌入式系统千万注意指针转换,尤其是不同类型的指针转换,通常,不同的数据类型有各自的内存对齐规则!