80x86 整数算术指令详解
在汇编语言中,算术表达式的编码离不开各种算术指令。下面将详细介绍 80x86 指令集中的一些重要算术指令。
1. mul 和 imul 指令
在 80x86 指令集中,乘法指令展现出了一些不规则性。像 add、sub 等指令和 mov 指令一样,支持两个操作数。但由于 80x86 操作码字节的位数有限,无法支持所有指令,所以 mul(无符号乘法)和 imul(有符号整数乘法)指令被当作单操作数指令,类似于 inc、dec 和 neg 指令。
然而,乘法本质上是一个双操作数的函数。为了解决这个问题,80x86 总是假定累加器(AL、AX 或 EAX)为目的操作数。这种不规则性使得在 80x86 上使用乘法比其他指令稍显复杂,因为其中一个操作数必须存于累加器中。Intel 采用这种非正交的方法,是认为程序员使用乘法的频率远低于 add 和 sub 等指令。
另外,mul 和 imul 指令不能直接将累加器与常量相乘。为此,Intel 增加了 intmul 指令来解决这个问题。但要注意,基本的 mul 和 imul 指令并不像 intmul 那样支持全范围的操作数。
乘法指令有两种形式,即无符号乘法(mul)和有符号乘法(imul)。与加法和减法不同,有符号和无符号操作需要使用不同的指令。
乘法指令的形式如下:
- 无符号乘法:
mul( reg8 ); // 返回 "ax"
mul( reg16 ); // 返回 "dx:ax"
mul( reg32 ); //
超级会员免费看
订阅专栏 解锁全文
1616

被折叠的 条评论
为什么被折叠?



