|
主题 : : 求人解答。 [待解决] |
回复[ 7次 ]
点击[ 538次 ] | |
|
|
|
|
[帖 主]
[ 发表时间:2010-09-06 08:48 ]
[引用]
[回复]
[ top ] | |
荣誉值:2
信誉值:0
注册日期:2010-03-03 23:27 |
table: dw sub1,sub2,sub3,sub4
set: push ax
push bx
cmp ah,3
ja sret
mov bl,ah
mov bh,0
add bx,bx ----------->这里为什么要bx*2
call word ptr table[bx]
sret: pop bx
pop ax
ret
------------------------------------------------
我的理解是:table[bx]是内存单元(表示的是字节),而dw定义的table中调用sub1,sub2,sub3,sub4,
这4个子程序是字,1个字=2个字节,所以要add bx,bx ,是不是这样理解的? | | |
|
|
|
|
[第1楼]
[ 回复时间:2010-09-06 18:32 ]
[引用]
[回复]
[ top ] | |
荣誉值:268
信誉值:12
注册日期:2010-06-18 22:19 |
你理解的跟我一样。sub1--sub4对应的起始地址是0000,0002,0004,0006 。AH的功能号分别对应的偏移地址是:
1--->0000
2--->0002
3--->0004
4--->0006 | | |
|
|
|
|
[第2楼]
[ 回复时间:2010-09-06 21:01 ]
[引用]
[回复]
[ top ] | |
荣誉值:2
信誉值:0
注册日期:2010-03-03 23:27 |
to masmaster :
那是不是像table[bx],ds[bx]....等都是表示一个字节呢? | | |
|
|
|
|
[第3楼]
[ 回复时间:2010-09-07 20:13 ]
[引用]
[回复]
[ top ] | |
荣誉值:2
信誉值:0
注册日期:2010-03-03 23:27 |
2天了,都还没个人来解答。
来位知道为什么要add bx,bx,给解释下。 | | |
|
|
|
|
[第4楼]
[ 回复时间:2010-09-07 20:47 ]
[引用]
[回复]
[ top ] | |
荣誉值:268
信誉值:12
注册日期:2010-06-18 22:19 |
to masmaster :
那是不是像table[bx],ds[bx]....等都是表示一个字节呢?
------------------
回复:请看第八章8.5 指令要处理的数据有多长 | | |
|
|
|
|
[第5楼]
[ 回复时间:2010-09-07 21:13 ]
[引用]
[回复]
[ top ] | |
荣誉值:2
信誉值:0
注册日期:2010-03-03 23:27 |
mov bl,ah
mov bh,0
add bx,bx ----------->这里为什么要bx*2 2个问题
call word ptr table[bx]
----------------------------------
ah是8位寄存器(字节),用来传送子程序编号。
bx是16位寄存器(字),已经是word了,为什么还要add bx,bx呢?
还有就是add bx,bx的话,那不就是dd(双字)了吗?
2个问题怎么就是没个人能解答下。 | | |
|
|
|
|
[第6楼]
[ 回复时间:2011-05-08 18:49 ]
[引用]
[回复]
[ top ] | |
荣誉值:4
信誉值:0
注册日期:2010-10-09 17:53 |
add bx,bx后,还是16位寄存器呀,怎么可能变成dd双字 | | |
|
|
|
|
[第7楼]
[ 回复时间:2019-02-20 12:29 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:2
注册日期:2011-11-27 16:20 |
table: dw sub1,sub2,sub3,sub4
因为这里面定义的字型数据,而非字节型,因此sub1所在内存偏移地址为0,sub2所在内存偏移地址为2,sub3所在内存偏移地址为4,sub4所在内存偏移地址为6。而bx中的商是由0/30,30/30,60/30等得到的,也即0,1,2等,那么用商去寻找偏移地址就会导致ds[0], ds[1],ds[2],真正应该寻找的是ds[0],ds[2],ds[4],所以add命令来使得商加倍。 | | |