用这段代码来给你说明吧
int a[6]={1,2,3,4,5,6};
int *k=a;
int x = *(k++);
printf("%d",x,);
反汇编
int x = *(k++);
00811698 mov eax,dword ptr [ebp-2Ch]
0081169B mov ecx,dword ptr [eax]
0081169D mov dword ptr [ebp-38h],ecx // 先把*k的值赋值给x(也就是ptr [ebp-38h])
008116A0 mov edx,dword ptr [ebp-2Ch]
008116A3 add edx,4 // k++
008116A6 mov dword ptr [ebp-2Ch],edx
printf("%d",x);
008116A9 mov esi,esp
008116AB mov eax,dword ptr [ebp-38h] 输出x(ptr [ebp-38h])
008116AE push eax
可以看到 ,int x = *(k++); 被编译器处理成了 x = *k;k++;
这个是vs2010反汇编的结果,
优先级++高于*,并不是说 *(k++)就先执行++ 后执行*。
而是说++ 这个运算符 归属k ,还是归属(*k)
如果++归属k,那么就是k指针指向下一个k的地址 ,也就是k=k+1,等价于k = &a【1】
如果++归属(*k),那么就是k的指向内容递增1 ,也就是 *(k) = *(k)+1 ,等价于a【0】 = a【0】+1;
[
本帖最后由 yuccn 于 2013-12-24 09:23 编辑 ]