|
主题 : : 偏移地址[X]可不可以是8位寄存器 [待解决] |
回复[ 7次 ]
点击[ 530次 ] | |
|
|
|
|
[帖 主]
[ 发表时间:2013-05-31 16:15 ]
[引用]
[回复]
[ top ] | |
荣誉值:4
信誉值:0
注册日期:2010-01-27 19:28 |
跟章节没什么关系,大概看到5.8节时突然想到的
MOV AL,[BL] ;偏移地址可不可以是8位寄存器
MOV AL,DS:[BH] | | |
|
|
|
|
[第1楼]
[ 回复时间:2013-06-20 14:33 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2013-06-15 10:10 |
|
|
|
|
|
[第2楼]
[ 回复时间:2013-07-16 17:55 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2013-07-14 15:44 |
回复:[贴 主]
------------------
debug 试了下,不可以 | | |
|
|
|
|
[第3楼]
[ 回复时间:2013-07-26 15:41 ]
[引用]
[回复]
[ top ] | |
荣誉值:26
信誉值:0
注册日期:2013-07-15 09:25 |
似乎只能是[bx]与[idata]。在做本章实验4时,为在9条指令内完成,不留心随意将[bx]就写成了[dx]。编译时总是:“error A204B:Must be index or base register”。改为[bx]就顺利通过了。 | | |
|
|
|
|
[第4楼]
[ 回复时间:2013-07-27 16:04 ]
[引用]
[回复]
[ top ] | |
荣誉值:4
信誉值:0
注册日期:2013-05-23 21:42 |
偏移地址是16位,8位放不下,所以用[BL]的话,编译器不能“识别”这是什么东西 | | |
|
|
|
|
[第5楼]
[ 回复时间:2014-11-22 22:37 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2014-11-08 19:06 |
偏移地址的长度是16位,即便是0000也是,所以一定要是16位寄存器 | | |
|
|
|
|
[第6楼]
[ 回复时间:2014-11-25 21:47 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2014-11-25 21:40 |
|
|
|
|
|
[第7楼]
[ 回复时间:2015-01-13 20:30 ]
[引用]
[回复]
[ top ] | |
荣誉值:0
信誉值:0
注册日期:2015-01-04 21:38 |
使用寄存器间址寻址,只能使用BX BP SI DI四个寄存器中的一个,不可以使用其他寄存器。32为程序才可以使用任意32为寄存器间址寻址。assume cs:code
code segment
dw 1,2,3,4
mov ax,20h
mov ds,ax
mov bl,0
mov dx,cs:[bl]
mov ds:[bl],dx
mov ax,4c00h
int 21h
code ends
end
编译时:“error A204B:Must be index or base register”。说的就是这个问题,你要么用变址(SI DI),要么用基址(BX BP),这里面只有BX分BL BH。你用BL,就行代码中那样是不可以的,因为它不属于BX BP SI DI四个寄存器中的任何一个。 | | |