汇编语言下--如何防止除法溢出

我们都知道:

 无符号数除法指令--格式为:

DIV mem/reg8 ; AH余数,AL商← AX / mem/reg8

DIV mem/reg16 ; DX余数,AX商← DX:AX / mem/reg8

与被除数和除数一样,商和余数也都为无符号数。DIV 指令执行后,所有标志均无定义。

整数除法指令--格式为:

IDIV mem/reg8 ; AX ← AX / mem/reg8
IDIV mem/reg16 ; DX:AX ← DX:AX / mem/reg16

对DIV和IDIV指令,如果字节操作时,被除数的高8 位绝对值大于除数的绝对值,或在字操作时,被除数的高16 位绝对值大于除数的绝对值,就会产生溢出,也就是说结果(商)超过了目标寄存器AL 或AX 所能存放数的范围。
结果溢出时,计算机会自动产生一个中断类型号为0的除法错中断,相当于执行了除数为0的运算,所得的商和余数都不确定。
对于无符号数,字节操作时,允许最大商为FFH,字操作时最大商为FFFFH,若超过这个范围就会溢出。对于带符号数,字节操作时商的范围为-127~+127,字操作时商的范围为-32767~ +32767。

但如果所得结果太大时,就会出现溢出:如DX:AX(12345678H) / BX(11H)   

当作除法动作所得商大于AX所能存储的字节范围时,就会溢出。

解决办法是:

;DX:AX(12345678H) / BX(11H)
        MOV BX,11H     ;BX为除数
        MOV DX,5678H   ;DX存高位
        MOV AX,1234H   ;AX存低位
        MOV DI,AX      ;先保存好低位

                        ;先计算高位,所得商AX即为最后商的高位
                        ;         所得余DX即为接下来低位运算的DX
        MOV AX,DX
        MOV DX,0
        DIV BX
                        ;再计算低位,所得商AX即为最后商的低位
                        ;          所得余DX即为最后的余
        MOV AX,DI
        DIV BX
         
时间: 2024-08-04 12:00:33

汇编语言下--如何防止除法溢出的相关文章

windows下简单的缓冲区溢出之slmail

缓冲区溢出是什么? 当缓冲区边界限制不严格时,由于变量传入畸形数据或程序运行错误,导致缓冲区被"撑暴",从而覆盖了相邻内存区域的数据 成功修改内存数据,可造成进程劫持,执行恶意代码,获取服务器控制权等后果 POP3   PASS 命令存在缓冲区溢出漏洞   无需身份验证实现远程代码执 软件下载 slmail          http://slmail.software.informer.com/5.5/ mona.py      https://github.com/corelan/

IE11下javascript报堆栈溢出问题的解决

在IE11浏览器下,使用日期函数里面的toLocaleDateString()会报堆栈溢出 不知道是不是跟我的其他相关代码有关,还是就是这个toLocaleDateString()在IE11确实不太一样,不管了,解决问题就行. 修改之前的代码: var myDate= new Date(); var str = myDate.toLocaleDateString(); 修改之后的代码: var myDate= new Date(); var str = myDate.getFullYear()

使用 CSS overscroll-behavior 控制滚动行为:自定义下拉刷新和溢出效果

CSS 的新属性 overscroll-behavior 允许开发者覆盖默认的浏览器滚动行为,一般用在滚动到顶部或者底部. 背景 滚动边界和滚动链接(boundary & chaining) 在 APP 中经常使用的抽屉导航(drawer)中,我们期望的效果是:滚动到底部时,滚动停止,因为我们到达了"滚动边界". 但是在 Web 页面中滚动并不会停止,而是继续滚动抽屉后面的内容.效果如下: 我们称这种行为叫滚动链接(scroll chaining). 下拉刷新 pull-to-

-webkit-line-clamp下多行文字溢出点点点...

限制在一个块元素显示的文本的行数. -webkit-line-clamp 是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中. 为了实现该效果,它需要组合其他外来的WebKit属性.常见结合属性: display: -webkit-box; 必须结合的属性 ,将对象作为弹性伸缩盒子模型显示 . -webkit-box-orient 必须结合的属性 ,设置或检索伸缩盒对象的子元素的排列方式 . text-overflow,可以用来多行文

linux下解决Tomcat内存溢出问题

修改catalina.sh文件. 在# OS specific support. $var _must_ be set to either true or false.下,添加以下信息 JAVA_OPTS="-Xms512m -Xmx1024m -Xss1024K -XX:PermSize=128m -XX:MaxPermSize=256m" 大小按实际需要修改.

Debug模式下编译溢出问题

问题: 代码在Debug模式下编译报出内存溢出的错误,而Release模式下则没有. 由于Debug模式下包含调试信息,并且不作任何优化.而Release模式进行了各种优化,内存检测等操作均省去,使得程序在代码大小和运行速度上都是最优的. 方法1: 猜测Release对代码进行了优化或者根本就没有进行内存检测,才导致Release模式下编译通过的.于是我进行了代码缩减,删除没有用的变量,问题仍然没有解决. 方法2: 我发现在Debug模式下,main.c文件淡黄色, ,Release模式下仍然为

兼容性—IE6下文字溢出

两个浮动元素之间用内联元素或者注释并且和父级宽度不超过3px,IE6下出产生文字溢出bug,具体代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> .wrap{ width: 400px; } .left{ float: left; }

汇编语言---call和ret指令

汇编语言--call和ret指令 call和ret指令 call和ret指令都是转移指令,它们都修改IP,或同时修改CS和IP. 它们经常被共同用来实现子程序的设计. ret和retf ret指令用栈中的数据,修改IP的内容,从而实现近转移: retf指令用栈中的数据,修改CS和IP的内容,从而实现远转移. CPU执行ret指令时,进行下面的两步操作: (1)(IP) = ((ss)*16 +(sp)) (2)(sp) = (sp)+2 CPU执行retf指令时,进行下面四步操作: (1)(IP

缓存区溢出攻击实验(3)

缓存区溢出攻击实验(3) 本实验预计分 3 个小实验来做,本文是第三个实验. 缓存区溢出攻击实验(1) 缓存区溢出攻击实验(2) 缓存区溢出攻击实验(3) 本实验跪谢大神 YSunLIN 的帮助与指导 ~ 不保证成功,一切皆有可能 ~ 背景介绍 请参照实验(1)(2). 实验目的 最终目的:只给一个需要输入正确的序列号才能验证通过的exe可执行文件,要求在不知道源代码的情况下利用缓存区溢出攻击来破解该exe文件. 注意!!! 不知道源代码的情况下 不知道源代码的情况下 不知道源代码的情况下 现实