今天我们来逆向分析C语言中++和—运算符前缀和后缀的区别!
提到这里,相信有不少小伙伴也早有过疑问,如前缀++表示”先加再用”,后缀++表示”先用再加”,今天经过我们的逆向分析,相信大家就会更加理解这其中的意义!
我们这里以++为例,分别进行逆向分析实验,观察汇编代码,先看一个简单的程序:
在++语句之前,我们下断点,然后点击view-Debug Windows-Disassembly 打开反汇编窗口,可以看到a = i++;这句话对应的汇编语句,如下:
重点就是这五条汇编语句,请大家对照;后面的注释逐条分析!
———————————
;先把变量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]<