程序执行过程的跟踪:(用debug来跟踪一个程序的运行过程) 整理总结

1.理由:在DOS中运行一个程序的时候,是由command将程序可执行文件中加载入内存,
并得以执行的。但是我们看不到程序逐步执行的过程,因为command的程序加载和设置cs:IP指向程序的入口的操作是连续完成的,而当cs:ip一指向程序的入口,command就放弃了cpu的控制权,cpu立即开始执行程序,直到程序结束。
2.目的:为了观察程序的执行过程,可以使用Debug。Debug可以把程序加载入内存,设置CS:IP执行程序的入口,但是Debug不放弃对cpu的控制,故可以用Debug逐步执行程序。
3方法:
(1)在提示符后输入:debug target.exe,按下enter键后,Debug将程序target.exe加载入内存,进行行相关的初始化后设置cs:ip指向程序的入口。
(2)用r命令查看各个寄存器的值可知:cx中放的是程序的长度。
(3)DOS系统中.exe文件中的程序加载过程。这里面主要的是理解:为什么程序的地址被设置为:SA+10H:0,下面是我的理解:在图4.20的第二步骤中,它有这样一句话:在这段内存区的前256个字节中,创建了psp的数据区。同时在第三步骤中有这样的一句话:从这段内存区的256字节处开始将程序装入。这段内存区的起始地址为SA,同时又有256字节的内存已被占用,而256用16进制表示就是100h,用偏移地址表示就是10H:0,转换成十进制表示是1×16×16=256。综上所述,程序的地址被设置成SA+10H:0,其实这里的关键是要看到10H:0 =0100H,同时10H:0是一个整体。也许这样看会更清楚:((10H:0)+SA)。所以CS:IP的值就是((10H:0)+SA),最后段地址放入了DS中即DS=SA.
(4)接下来可以使用Debug中的命令如r,t,a,u,等来对程序进行调试,但是执行到int 21 时,因该用p命令去执行,然后程序将会正常停止。
(5)使用debug加载程序时的顺序是:command加载Debug,Debug加载target.exe。返回的顺序是:从target.exe中的程序返回到Debug,从Debug返回到command。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值