Ⅰ 汇编语言[bx+si]和[bx+di]方式寻址
[bx+si]和[bx+di]方式指定地址
[bx+si]表示一个内存单元
偏移地址为(bx)+(si)(即bx中的数值加上si中的数值)
指令mov ax,[bx+si]的含义
将一个内存单元的内容送入ax
这个内存单元的长度为2个字节(字单元),存放一个字
偏移地址为bx中的数值加上si中的数值
段地址在ds中
指令 mov ax,[bx+si]的数学化的描述
(ax) = ((ds)*16 + (bx)+(si))
其他写法mov ax,[bx+si]其他写法
mov ax,[bx][si]
应用案例
在内存中数据2000:1000 BE 00 06 00 00 ........
程序执行后ax bx cx中内容。
mov ax,2000H
mov ds,ax
mov bx,1000H
mov si,0
mov ax,[bx+si]
inc si
mov cx,[bx+si]
inc si
mov di,si
mov ax,[bx+di]
[bx+si+idata]和[bx+di+idata]
[bx+si+idata]表示一个内存单元
偏移地址为(bx)+(si)+idata j即bx中的数值加上si中的数值加上idata
指令 mov ax,[bx+si+idata]的含义
将一个内存单元的内容送入ax
这个内存单元的长度为2个字节(字单元),存放一个字
偏移地址为bx中的数值加上si中的数值再加上idata,段地址在ds中
数学化描述
(ax) = ((ds)*16 + (bx)+(si)+idata)
指令mov ax,[bx+si+idata]的其他写法
mov ax,[bx+200+si] mov ax,[bx].200[si]
mov ax,[200+bx+si] mov ax,[bx][si].200
mov ax,200[bx][bx] mov ax,[bx][si]
对内存的寻址方式
assume cs:code,ds:data
data segment
db '1. file '
db '2. edit '
db '3. search '
db '4. view '
db '5. options '
db '6. help '
data ends
code segment
start:
mov ax,data
mov ds,ax
mov bx,0
mov cx,6
s1:mov al,[bx+3]
and al,11011111b
mov [bx+3],al
add bx,16
loop s1
mov ax,4c00h
int 21h
code ends
end start
; 可以看成一个数组6*16
; 因为每个单词的开头字母都是在每一行的第三个,利用[bx+idata]方式
assume cs:codesg,ds:datasg,ss:stack
datasg segment
db 'ibm '
db 'dec '
db 'dos '
db 'vax '
datasg ends
stack segment
dw 0,0,0,0,0,0,0,0,0,0,0,0
stack ends
codesg segment
start:
mov ax,stack
mov ss,ax
mov sp,16
mov ax,datasg
mov ds,ax
mov bx,0
mov cx,4
s2:push cx ;将外层循环的值赋值给4
mov si,0
mov cx,3
s1:mov al,[bx+si]
and al,11011111b
mov [bx+si],al
inc si
loop s1
add bx,16
pop cx
loop s2
mov ax,4c00h
int 21h
codesg ends
end start
; 将dataseg段中每个单词改写为大写字母
; 利用栈的形式去存储 目前是最安全的.
Ⅱ 汇编语言中[BX]表示什么
bx代表一个寄存器,[bx]代表一个内存地址,段地址默认在ds中,偏移地址在bx中,即ds:bx。一般[bx]做变量使用。有什么问题加q讨论,我也是汇编爱好者。qq:7234801