详解汇编语言中乘法指令:MUL、IMUL
2017-11-13 15:58
711 查看
本文参考了马维华老师的《微机原理与接口技术》一书
指令格式:
MUL REG/MEM ;REG寄存器,MEM存储器
IMUL REG/MEM
MUL和IMUL指令分别用于实现无符号数的乘法和有符号数的乘法运算。都只有一个源操作数,可以使寄存器或存储器,而且目标操作数隐含规定在累加器中。
1)MUL指令
(a)、字节乘法,则AL×REG8/MEM8,乘积存于AX中。
(b)、字乘法,则AX×REG16/MEM16,乘积的高16位存放在DX中,低16位存放在AX中。
(c)、32位乘法,则EAX×REG32/MEM32,乘积的高32位存放在EDX中,低32位存放在EAX中。
(d)、64位乘法,则RAX×REG64/MEM64,乘积的高64位存放在RDX中,低64位存放在RAX中。
当乘积的高半部分(AH、DX、EDX、RDX)中存有结果的有效数字,则CF=OF=1,否则CF=OF=0。
2)IMUL指令
IMUL指令除了是完成两个有符号数的相乘以外,其他与MUL完全类似。
注:由于乘法指令为乘积保留了两倍于原来操作数的存储空间,因而不会出现溢出。
指令格式:
MUL REG/MEM ;REG寄存器,MEM存储器
IMUL REG/MEM
MUL和IMUL指令分别用于实现无符号数的乘法和有符号数的乘法运算。都只有一个源操作数,可以使寄存器或存储器,而且目标操作数隐含规定在累加器中。
1)MUL指令
(a)、字节乘法,则AL×REG8/MEM8,乘积存于AX中。
(b)、字乘法,则AX×REG16/MEM16,乘积的高16位存放在DX中,低16位存放在AX中。
(c)、32位乘法,则EAX×REG32/MEM32,乘积的高32位存放在EDX中,低32位存放在EAX中。
(d)、64位乘法,则RAX×REG64/MEM64,乘积的高64位存放在RDX中,低64位存放在RAX中。
当乘积的高半部分(AH、DX、EDX、RDX)中存有结果的有效数字,则CF=OF=1,否则CF=OF=0。
2)IMUL指令
IMUL指令除了是完成两个有符号数的相乘以外,其他与MUL完全类似。
注:由于乘法指令为乘积保留了两倍于原来操作数的存储空间,因而不会出现溢出。
相关文章推荐
- 汇编语言 2位十六进制数(字符),转换成数值保存到字节变量num(需要用逻辑左移指令或乘法指令)
- 汇编----乘指令: MUL、IMUL
- 8086乘法指令MUL,IMUL
- 学 Win32 汇编[27] - 乘除指令: MUL、IMUL、DIV、IDIV
- 8086汇编语言自学经验分享 两个8位数据相乘mul byte ptr指令
- 8086汇编语言自学经验分享 mul word ptr 指令示例16位乘以16位
- 汇编语言基础教程-乘法指令
- Win32 汇编 - 乘除指令: MUL、IMUL、DIV、IDIV
- int指令03 - 零基础入门学习汇编语言66
- PIC8位单片机汇编语言常用指令的识读(中)
- 汇编语言学习笔记18086指令系统
- 汇编语言学习:汇编指令:MOV指令
- 汇编语言条件转移(短转移)指令列表
- 每日一课(20/75)汇编语言指令系统简介
- 用汇编语言实现冒泡排序——基于MIPS指令系统
- [汇编语言]-第八章 div指令,伪指令dd,dup
- 汇编语言指令大全最新发布完整版
- 汇编语言基础教程-指令:传送,交换,取地址
- 【汇编语言/底层开发】9、转移指令的原理
- 转移指令的原理04 - 零基础入门学习汇编语言46