• 汇编语言MUL指令:无符号数乘法

    32 位模式下,MUL(无符号数乘法)指令有三种类型:

    • 第一种执行 8 位操作数与 AL 寄存器的乘法;
    • 第二种执行 16 位操作数与 AX 寄存器的乘法;
    • 第三种执行 32 位操作数与 EAX 寄存器的乘法。

    乘数和被乘数的大小必须保持一致,乘积的大小则是它们的一倍。这三种类型都可以使用寄存器和内存操作数,但不能使用立即数:

    MUL reg/mem8
    MUL reg/meml6
    MUL reg/mem32

    MUL 指令中的单操作数是乘数。下表按照乘数的大小,列出了默认的被乘数和乘积。由于目的操作数是被乘数和乘数大小的两倍,因此不会发生溢岀。

    被乘数 乘数 乘积
    AL reg/mem8 AX
    AX reg/mem16 DX:AX
    EAX reg/mem32 EDX:EAX

    如果乘积的高半部分不为零,则 MUL 会把进位标志位和溢出标志位置 1。因为进位标志位常常用于无符号数的算术运算,在此我们也主要说明这种情况。例如,当 AX 乘以一个 16 位操作数时,乘积存放在 DX 和 AX 寄存器对中。其中,乘积的高 16 位存放在 DX,低 16 位存放在 AX。如果 DX 不等于零,则进位标志位置 1,这就意味着隐含的目的操作数的低半部分容纳不了整个乘积。

    有个很好的理由要求在执行 MUL 后检查进位标志位,即,确认忽略乘积的高半部分是否安全。

    MUL 示例

    下述语句实现 AL 乘以 BL,乘积存放在 AX 中。由于 AH(乘积的高半部分)等于零,因此进位标志位被清除(CF=0):

    mov al, 5h
    mov bl, 10h
    mul bl                    ; AX = 0050h, CF = 0

    下图展示了寄存器内容的变化:

更多...

加载中...