有人能澄清我的错误解释吗?我知道我的理解是不正确的,因为我的代码的结果输出(请参阅问题的底部)。 在此先感谢。指针访问和数组访问之间的值差异
为了澄清,什么是以下行的每个段的意思是?:
*(u8 *)((u32)BufferAddress + (u32)i)
它是如何从以下线路不同:
*(u32 *)((u32)BufferAddress + (u32)i)
我上面的解释是:
- segment1 =((u32)BufferAddress +(u32)i)=>确定一个地址为一个整数。
- segment2 =(u32 *)(segment1)=>将指针处理为待处理地址,其中指针的长度为32位。
- segment3 = *(segment2)=>取消引用指针以获取驻留在计算出的地址的值。
我的解释是什么不正确?我认为我的缺乏理解在第二部分领域...铸造(u32 *)和(u8 *)有什么区别?
这里是让我意识到我有知识差距代码:
初始化代码:
main(...) {
...
u8 *Buffer = malloc(256);
...
Buffer[0] = 1;
Buffer[1] = 0;
Buffer[2] = 0;
Buffer[3] = 4;
Buffer[4] = 0;
Buffer[5] = 0;
qFunction(... , Buffer, 6, ...);
...
}
qFunction(... , const u8 *BufferPointer, u32 BufferLength, ...) {
u32 BufferAddress;
...
BufferAddress = (u32) BufferPointer;
...
/* Method 1: */
for (i=0; i < BufferLength; i++)
printf("%d, %p\n", BufferPointer[i], &BufferPointer[i]);
/* Method 2: */
for (i=0; i < BufferLength; i++)
printf("%d, 0x%lx\n", *(u8 *)(BufferAddress+i), BufferAddress+i);
/* Method 3: */
for (i=0; i < BufferLength; i++)
printf("%d, 0x%lx\n", *(u32 *)(BufferAddress+i), BufferAddress+i);
...
}
方法1和方法2的输出如我所料(两者都相同):
1, 0x1000000
0, 0x1000001
0, 0x1000002
4, 0x1000003
0, 0x1000004
0, 0x1000005
但是,方法3的输出对我来说似乎很奇怪;只有部分结果与方法1/2相同:
-1442840511, 0x1000000
11141120, 0x1000001
43520, 0x1000002
4, 0x1000003
0, 0x1000004
0, 0x1000005
我很感激任何提示或参考资料。 谢谢。
macduff的回答是正确的,但是一个评论加上;你应该尽量避免将指针转换为整数,因为这是不必要的,如果将来决定构建64位(指针将是64位而不是32位),会导致问题。 –