汇编语言学习笔记1
程序员文章站
2022-03-13 10:46:41
...
在一个程序中使用多个段
assume cs:code, ds:data, ss:stack
data segment
dw 0123h, 0456h, 0789h, 0abch, 0defh, 0fedh, 0cbah, 0987h
data ends
stack segment
dw 0,0,0,0,0,0,0,0
stack ends
code segment
start: mov ax, stack
mov ss, ax
mov sp, 16
mov ax, data
mov ds, ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax, 4c00h
int 21h
code ends
end start
ss = 0B4A
ds = 0B3A
看这段代码,我们使用了多个段,相比原来的程序,我们添加了自己定义的data段和stack段
程序开始的地方的段地址是:ds+10H
这样我们就可以计算出data段的段地址以及stack段的段地址
还有一点要说明的就是:
0B4A:10等价于0B4B:0
下面这段代码可以实现a段数据中的前8位地址单元,倒序传输到b段中
一般情况下,倒序输入输出都是用栈结构来实现的
assume cs:code
a segment
dw 1, 2, 3, 4, 5, 6, 7, 8, 9, 0ah, 0bh, 0ch, 0dh, 0eh, 0fh, 0ffh
;注意:此处申请的是字单元,在本书中,一个字占2字节
a ends
b segment
dw 0,0,0,0,0,0,0,0
b ends
code segment
start: mov ax, b
mov ss, ax
mov sp, 16
mov ax, a
mov ds, ax
mov bx, 0
mov cx, 8
s1: push [bx]
add bx, 2
loop s1
mov bx, 0
mov cx, 8
s2: pop [bx]
add bx, 2
loop s2
mov ax, 4c00h
int 21h
code ends
end start
程序执行前a段数据单元中的数据
程序执行完毕后: