• 学习:CMP/TEST比较指令


    cmp指令:比较

    cmp指令,和sub指令的最大的不同点就是cmp指令是影响标志位 不储存结果

    1、当前汇编指令为cmp edx,ecx

    2、当前ecx寄存器中的地址为00000001,edx寄存器中的地址00000000,相当于 edx = edx - ecx

    3、单步步过

    结果发现ecx寄存器中没有变化

    1、当前汇编指令为cmp eax,ecx

    2、当前eax寄存器中的地址为00000001,ecx寄存器中的地址00000001,相当于 eax = eax-ecx

    3、单步步过

    结果发现ecx寄存器中没有变化,但是发现Z标志位发生了变化 变为了1,也可以说明了当cmp指令为两个相减为0的时候,那么Z标志位为1

    如何进行对字符串的比较呢,这里自己理解的是对寄存器中的地址中的值进行比较比如如下

    再进行重新设置EIP然后单步步过,结果如下,发现Z标志位变0,所以大小不一致

    同样的,cmp影响的不只是Z标志位,之前S标志位是根据正负数来判断的,这里同样生效
    1、当前汇编指令为cmp eax,ecx

    2、当前eax寄存器中的地址为00000000,ecx寄存器中的地址00000001,相当于 eax = eax-ecx

    3、单步步过

    结果发现,S标志位为1,因为相减为负数

    当然,cmp指令不只是寄存器与寄存器之间,还可以寄存器与地址的值之间,比如:
    1、当前汇编指令为cmp eax,[402000]

    2、设置地址402000中的值为01

    3、单步步过

    结果Z为1 那么相减结果为0,S为0,那么结果不是负数


    test指令:对两个操作数进行与操作,同时影响符号标志位、零标志位和奇偶标志位

    test指令就是进行与运算,如果与运算结果为0那么Z标志位为1,反之为0

    1、当前汇编指令为cmp eax,ecx
    2、设置EAX寄存器地址为00000001,ECX寄存器地址00000010,
    3、单步步过

    发现Z标志位为1,说明是相等,00000001的二进制为‭‭00000001,‬ 00000010的二进制位为00010000,与运算结果为00000000‬‬

  • 相关阅读:
    十、CI框架之通过参数的办法输出URI路径
    九、CI框架之将URI转为数组原型
    八、CI框架之输出URI路径,相当于GET
    七、CI框架之分配变量数组,循环输出
    六、CI框架之分配变量
    五、CI框架之通过带路径的view视图路径访问
    四、CI框架之通过URL路径访问C中的函数
    三、CI框架之一个最简单的页面
    二、CI框架之MCV模型
    一、CI框架(CodeIgniter)简介
  • 原文地址:https://www.cnblogs.com/zpchcbd/p/12051837.html
Copyright © 2020-2023  润新知