zoukankan      html  css  js  c++  java
  • 【C语言是世界上最好的语言】逆向之自增(++)运算符前缀和后缀的区别!

    今天我们来逆向分析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]

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

    0040D728      add       ecx,1

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

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

    ———————————

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

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


     

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


     

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

    ——————————

    ;将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语言程序,观察对应汇编语句的变化。

    ——————————————————————

    - END -

    不管你是转行也好,初学也罢,进阶也可,如果你想学编程,进阶程序员~

    【值得关注】我的 编程学习交流俱乐部 !【点击进入】

    C语言入门资料(网盘链接免费分享):


     

    C语言推荐书籍(PDF免费分享):


     
  • 相关阅读:
    为什么企业发展离不开ERP系统?
    PS Cloud:Odoo在中国唯一的SaaS营销平台
    Ps cloud里的CRM软件到底强在何处?
    PS Cloud备受关注的六大优点
    odoo的 CRM系统为何如此受欢迎
    iOS :Object-C 语言merge两个字典对象
    iOS:swift :可选类型
    iOS循环引用
    swift 3.0基本数据语法
    配置React Native环境
  • 原文地址:https://www.cnblogs.com/huya-edu/p/15048595.html
Copyright © 2011-2022 走看看