. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->INT指令
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  检测点 13.1 (2)  [待解决] 回复[ 9次 ]   点击[ 1166次 ]  
zhenglxd
[帖 主]   [ 发表时间:2009-06-03 15:46 ]   [引用]   [回复]   [ top ] 
荣誉值:30
信誉值:0
注册日期:2009-04-09 10:05
;jmp 是无条件转移指令感觉做起来更加简单
;我这个程序和书上例子不一样,是比较完整的程序
;cld很重要刚忘记加了结果- -
;7ch*4(因为对于每个 中断类型码入口地址 大小是2个字的) 我老忘记结果调试了半天大家要引以为戒啊!
;还是不仔细啊 调试中显存段地址是 0b800忘记打上b了,引以为戒啊!
;终于独立完成了貌似构思才花了不到半小时,由于粗心调试了将近4小时
;TNND orz!

assume cs:code
data segment
  db 'conversation',0
data ends
code segment
start:mov ax,0
      mov es,ax
      mov word ptr es:[7cH*4],200H
      mov word ptr es:[7cH*4+2],0  
           ;7ch中断类型码指向0:200
        
      mov cx,offset jmp_nearE-offset jmp_near   
      mov ax,cs     
      mov ds,ax   
      mov si,offset jmp_near      
          ;ds:si 指向源地址 jmp_near

      mov ax,0
      mov es,ax
      mov di,200H
          ;es:di 指向目标地址 0:200H
      cld
      rep movsb           
          ;安装程序(进行 jmp_near到0:200H 代码copy)    
      

st2  :mov ax,data
      mov ds,ax
      mov si,0
      mov ax,0b800h
      mov es,ax
      mov di,12*160+72
 st2s:cmp byte ptr ds:[si],0
      je ok
      mov al,[si]
      mov es:[di],al
      mov byte ptr es:[di+1],2       ;设置颜色
      inc si
      add di,2
      mov bx,offset st2s
      int 7ch

ok:   mov ax,4c00H
      int 21H

jmp_near:push bp
         mov bp,sp
         mov ss:[bp+2],bx
         pop bp
         iret
        ;进行循环因为是near循环段地址不变所以bx直接=st2s

jmp_nearE:nop

code ends

end start
ilove
[第1楼]   [ 回复时间:2009-06-09 15:39 ]   [引用]   [回复]   [ top ] 
荣誉值:14
信誉值:2
注册日期:2008-10-19 21:37
后面的程序越来越舒服了,用计算机也很快能判断错误进而调整,是潜心研究的好内容。
jhchen002
[第2楼]   [ 回复时间:2009-06-16 08:21 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2009-05-04 20:45
谢谢分享你的教训,好人啊,呵呵。
yiyn
[第3楼]   [ 回复时间:2010-01-07 19:32 ]   [引用]   [回复]   [ top ] 
荣誉值:9
信誉值:0
注册日期:2009-10-18 04:41
楼主这是实现13.1(2)吗>用7ch实现jmp near ptr s的功能,我想说的是你这似乎错了,请你回过头仔细看看jmp near ptr s的功能,还有他的跳转范围,是-32768到正的32767
jmp_near:push bp 
         mov bp,sp 
         mov ss:[bp+2],bx 
         pop bp 
         iret 
你这段显然是不能实现的,当然你这调试出来是没有什么问题的,我的意思是你这没有达到让bx在这个范围内
361283028
[第4楼]   [ 回复时间:2010-01-12 00:47 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-01-05 19:25
楼上的回答太狭隘了,作者的意图是让我们完成jmp near ptr s的功能,只要完成它修改ip的功能就可以了,没有必要严格限定它的范围,这偏离了作者的目的。书上完成loop指令的功能也并未限制它的范围在-128~127之间。
coolman
[第5楼]   [ 回复时间:2010-02-28 21:52 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-02-02 15:08
3楼的说法是受了13.1(1)loop循环是短跳转的误导。具体到 jmp near ptr s 它的跳转范围是 -32768~32767没有错,我门是用bx 寄存器来传递的转移位移参数,而bx刚好是16位寄存器,它表示一个有符号数时的范围刚好是-32768~32767,两者一致,所以楼主的方法是可靠的。
    真正有问题的是书中对loop循环实现的例子。在那个例子中用bx传递转移位移参数,超出了loop循环真正的转移位移范围,正确的做法是用一个8位寄存器传递loop循环的转移位移。因此书中用int 7ch实现的loop循环有瑕疵。该实现中最大的转移范围是 -32768~32767,不是-128~127。该实现可以看作是对loop循环的一种扩展。
yangqingxiaogu
[第6楼]   [ 回复时间:2010-03-09 14:42 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:0
注册日期:2009-11-24 20:22
回复:[第5楼]
------------------
解释的如此到位  小弟学习了
masmaster
[第7楼]   [ 回复时间:2010-06-21 17:58 ]   [引用]   [回复]   [ top ] 
荣誉值:268
信誉值:12
注册日期:2010-06-18 22:19
3楼的说法是受了13.1(1)loop循环是短跳转的误导。具体到 jmp near ptr s 它的跳转范围是 -32768~32767没有错,我门是用bx 寄存器来传递的转移位移参数,而bx刚好是16位寄存器,它表示一个有符号数时的范围刚好是-32768~32767,两者一致,所以楼主的方法是可靠的。
    真正有问题的是书中对loop循环实现的例子。在那个例子中用bx传递转移位移参数,超出了loop循环真正的转移位移范围,正确的做法是用一个8位寄存器传递loop循环的转移位移。因此书中用int 7ch实现的loop循环有瑕疵。该实现中最大的转移范围是 -32768~32767,不是-128~127。该实现可以看作是对loop循环的一种扩展。
------------------
回复:学习啦
j03106
[第8楼]   [ 回复时间:2010-08-21 16:26 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:0
注册日期:2010-01-13 23:10
都是高手啊!!学习了!!
tq02vnc
[第9楼]   [ 回复时间:2010-11-06 16:46 ]   [引用]   [回复]   [ top ] 
荣誉值:2
信誉值:0
注册日期:2010-10-24 14:35
为什么不直接 mov bx,offset jmp_near  得到循环开头的标号地址
后面 直接把bx,赋值给栈里的数据.
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved