• 欢迎访问C语言网www.dotcpp.com 比赛栏每月有奖月赛!举办比赛联系QQ:2045302297
  • 问题反馈、粉丝交流 QQ群327452739 蓝桥杯训练群:113766799 申请群时请备注排名里的昵称
  • C语言研究中心 为您提供有图、有料、解渴的C语言专题! 欢迎讨论!

C语言逆向之自增(++)运算符前缀和后缀的区别

C语言研究中心 CTO 17179次浏览 0个评论

今天我们来逆向分析C语言中++和—运算符前缀和后缀的区别,提到这里,相信有不少同学也早有过疑问,如前缀++表示”先加再用”,后缀++表示”先用再加”,今天经过我们的逆向分析,相信大家就会更加理解这其中的意义!

 

 

我们这里以++为例,分别进行逆向分析实验,观察汇编代码,先看一个简单的程序:

 

C语言逆向之自增(++)运算符前缀和后缀的区别

 

 

在++语句之前,我们下断点,然后点击view-Debug Windows-Disassembly 打开反汇编窗口,可以看到a = i++;这句话对应的汇编语句,如下:

 

C语言逆向之自增(++)运算符前缀和后缀的区别

 

 

重点就是这五条汇编语句,请大家对照;后面的注释逐条分析!

 

;先把变量i保存到eax中

0040D71F      mov       eax,dword ptr [ebp-8]

;后把eax也就是i的值放到a里

0040D722      mov       dword ptr [ebp-4],eax

;把i的值取出来,放到ecx里

0040D725      mov       ecx,dword ptr [ebp-8]

;ecx进行+1,也就是++这个动作!

0040D728      add       ecx,1

;把ecx放回去,放到i里。完成!

0040D72B      mov       dword ptr [ebp-8],ecx

怎么样,大家看明白了吗?

 

 

下面,我们把代码改一下,将后缀++改为前缀++,再进行分析,代码如下:

C语言逆向之自增(++)运算符前缀和后缀的区别

 

 

还是在下断点,看反汇编语句,打开如下:

 

C语言逆向之自增(++)运算符前缀和后缀的区别

 

 

看一下,还是五条,我们复制出来,逐行分析:

;将i的值保存到eax里

0040D71F      mov       eax,dword ptr [ebp-8]

;把eax里的值加1

0040D722      add       eax,1

;把eax的值放回i里

0040D725      mov       dword ptr [ebp-8],eax

;把i里的值放到ecx里

0040D728      mov       ecx,dword ptr [ebp-8]

;把ecx里的值放到a里,完成!

0040D72B      mov       dword ptr [ebp-4],ecx

 

怎么样,大家看懂了吗?我们可以看出这里VC6其实把++和赋值(也就是”用”);分开处理,前缀就先加,后缀就先赋值。–与++类似,对应的汇编语句会由add变为sub,大家可以自行实验对比。

通过这个实验分析,想必一定会加深我们对前缀和后缀的区别。

建议大家亲自上机实验,可以适当改变C语言程序,观察对应汇编语句的变化。

 

以上

 

有发现问题欢迎大家随时沟通!

 

C语言研究中心(www.dotcpp.com)

 

C语言网提供「C语言、C++、算法竞赛」在线课程,全部由资深研发工程师或ACM金牌大佬亲授课,更科学、全面的课程体系,以在线视频+在线评测的学习模式学习,学练同步,拒绝理论派,真正学会编程!还有奖学金等增值福利等你!

C语言网, 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明C语言逆向之自增(++)运算符前缀和后缀的区别
喜欢 (31)
[jinyangH@aliyun.com]
分享 (0)
发表我的评论
取消评论
表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)