| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2503 人关注过本帖
标题:在虚拟模式下(win Xp), 中断程序的奇怪现象。
只看楼主 加入收藏
tigerdown
Rank: 1
等 级:新手上路
帖 子:72
专家分:8
注 册:2017-8-21
结帖率:64.29%
收藏
已结贴  问题点数:20 回复次数:2 
在虚拟模式下(win Xp), 中断程序的奇怪现象。
仅个人经验而己,不正确之处请指正。
实例:王爽书中(p240)有关除法错误0号中断程序:
Mov ax, 1000h
Mob bh, 1
Div bh
执行后会得到"divide overflow"除法溢出的错误信息。
这个divide overflow是从那里来的?根据0号中断向量表,它的程序入口地址在0:0~0:3, 在这里显示在00a7:1068地址.
图片附件: 游客没有浏览图片的权限,请 登录注册

然而,在那里并没有。进行搜索一下,
-s cs:0 1000 "Divide overflow", 这里cs=0, 发现在0000:0c7a。退出debug,再进入,用指令d 0000:0c7a再显示一下,你惊讶的发现那里是空的,再用同样的指令搜索,你发现它又在那里了,很奇怪,不是吗?!
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册

我猜这是因为某些特定指令触动系统加载了这个代码。这也许是虚拟模式的特征吧。
搜索更多相关主题的帖子: 虚拟 模式 中断 现象 指令 
2018-06-17 20:42
Valenciax
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:11
帖 子:340
专家分:2482
注 册:2016-5-15
收藏
得分:20 
搜索到 0000:0C7A的时候,应该输入
-D 0:C60   

这里会显示较前一些的位置,你会发现 'Divide overflow'不过是你键入的 [搜索资料] 本身,
并不是 [中断0] 的显示资料.

至于 [中断0] 的真身,在dos的时代是可追查的,也就是楼主那本书中的年代(至少30-40年前),

但到了winxp,win7,win10等等或者模拟器的虚拟环境, [中断0]已经过层层封装,隐藏在保护模式下的某个api中,
并不是楼主那个dos下的debug可以窥探的.正如一只地球上的蚂蚁,不可能想像到诸神之山 [奥林匹斯 Όλυμπος] 在天上的那一方.
2018-06-18 08:00
tigerdown
Rank: 1
等 级:新手上路
帖 子:72
专家分:8
注 册:2017-8-21
收藏
得分:0 
回复 2楼 Valenciax
确实如此, 谢了。
2018-06-18 08:10
快速回复:在虚拟模式下(win Xp), 中断程序的奇怪现象。
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.044658 second(s), 12 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved