C a[i]==a[++i]

本文探讨了C++中自增运算符的使用陷阱,特别是在表达式中的位置对结果的影响。通过具体的代码示例和反汇编代码分析,解释了为什么在比较操作中,前置自增和后置自增会导致不同的结果。

记录一下今天碰到的个坑

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进行自增的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值