记录一下今天碰到的个坑
int a[] = { 1,2,3,4,5 };
int i = 1;
cout << (a[++i] == a[i])<<endl;
i=1;
cout << (a[i] == a[++i]);

为什么我也不知道。。
填坑
i = 1;
005254FE mov dword ptr [i],1
cout << (a[i] == a[++i]);
00525505 mov eax,dword ptr [i]
00525508 add eax,1
0052550B mov dword ptr [i],eax
0052550E mov ecx,dword ptr [i]
00525511 mov edx,dword ptr [i]
00525514 mov eax,dword ptr a[ecx*4]
00525518 cmp eax,dword ptr a[edx*4]
这是部分反汇编代码
原来是因为i的自增操作不然就是放在整条语句之前(++i)不然就是放在整条语句之后(i++),在将==左右两边的数读进寄存器的时候是不对i进行自增的。
本文探讨了C++中自增运算符的使用陷阱,特别是在表达式中的位置对结果的影响。通过具体的代码示例和反汇编代码分析,解释了为什么在比较操作中,前置自增和后置自增会导致不同的结果。

664

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



