AT&T汇编中的除法指令也分为两种:signed、unsigned
unsigned:
div divisor //除数 a 8、16、32-bits register or memory value
被除数隐含的放在ax、dx:ax、edx:eax中
其中,除数的大小依据被除数大小有限制
1.如果被除数是16bits,那么除数最大只能是8bits
2.同理,被除数是32bits,那么除数最大是16bits
3.同理,被除数的64bits,那么除数最大是32bits
div指令后缀依据divisor大小变化。
除法指令的结果分为两个部分:商、余数
其中,除法指令后,依据被除数的存储情况,其低位存储运算结果的商,高位存储余数。
1.被除数是16bits,在存储在ax中,则运算后,al存储商,ah存储余数
2.同理,被除数32bits,运算后dx存商,ax存余数
3.被除数64bits,运算后edx存商,eax存余数
注意:
除法指令后,register 内容被改写,被除数内容将丢失,注意将其保存到别处。
测试代码:
signed:
idiv divisor //用法与unsigned的div指令一样
注意:
余数的符号与被除数一致
根据除法指令要求,被除数的大小是除数大小的两倍,所以经常要把一个数(一般其将被用作被除数)扩展大小,所以请根据除法指令是否有符号,选择不同的数据扩展指令,unsigned——movzx,signed——movsx!