|
主题 : : 检测点 13.1 (2) [待解决] |
回复[ 9次 ]
点击[ 1166次 ] | |
|
|
|
|
[帖 主]
[ 发表时间: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 | | |
|
|
|
|
[第1楼]
[ 回复时间:2009-06-09 15:39 ]
[引用]
[回复]
[ top ] | |
荣誉值:14
信誉值:2
注册日期:2008-10-19 21:37 |
后面的程序越来越舒服了,用计算机也很快能判断错误进而调整,是潜心研究的好内容。 | | |
|
|
|
|
[第2楼]
[ 回复时间:2009-06-16 08:21 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2009-05-04 20:45 |
|
|
|
|
|
[第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在这个范围内 | | |
|
|
|
|
[第4楼]
[ 回复时间:2010-01-12 00:47 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2010-01-05 19:25 |
楼上的回答太狭隘了,作者的意图是让我们完成jmp near ptr s的功能,只要完成它修改ip的功能就可以了,没有必要严格限定它的范围,这偏离了作者的目的。书上完成loop指令的功能也并未限制它的范围在-128~127之间。 | | |
|
|
|
|
[第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循环的一种扩展。 | | |
|
|
|
|
[第6楼]
[ 回复时间:2010-03-09 14:42 ]
[引用]
[回复]
[ top ] | |
荣誉值:2
信誉值:0
注册日期:2009-11-24 20:22 |
回复:[第5楼]
------------------
解释的如此到位 小弟学习了 | | |
|
|
|
|
[第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循环的一种扩展。
------------------
回复:学习啦 | | |
|
|
|
|
[第8楼]
[ 回复时间:2010-08-21 16:26 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2010-01-13 23:10 |
|
|
|
|
|
[第9楼]
[ 回复时间:2010-11-06 16:46 ]
[引用]
[回复]
[ top ] | |
荣誉值:2
信誉值:0
注册日期:2010-10-24 14:35 |
为什么不直接 mov bx,offset jmp_near 得到循环开头的标号地址
后面 直接把bx,赋值给栈里的数据. | | |