6.1 在代码段中使用数据
dw 就是定义字型数据。
;此处的start就是cs的位置,记住末尾上的end要加上start
assume cs:code
code segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h ;数据
start: mov bx,0 ;代码
mov ax,0
mov cx,8
s: add ax,cx:[bx]
add bx,2
loop s
mov ax,4c00
code ends
end start
6.2 在代码段中使用栈
assume cs:code
code segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h ;数据
dw 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 ;栈
start: mov ax,cs
mov ss,ax
mov sp,30h ;30h - 2 = 28h
mov bx,0
mov cx,8
s: push cx:[bx]
add bx,2
loop s
code ends
end start
检测点 6.1
mov cs:[bx],ax
cs
24h
pop cs:[bx]
6.3 将数据、代码、栈放入不同的段
8086模式的限制 当数据 、栈、代码需要的空间超过64KB就不能放在一个段中了。
assume cs:code ,ds:data, ss:stack
data segment
dw 0123h,0456h, 0789h, 0abch, 0defh, 0fedh, 0cbh, 0987h
data ends
stack segment
dw 0,0,0,0, 0,0,0,0,0 ,0,0,0,0 ,0,0,0,0
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,20h
mov ax,data
mov ds,ax
mov bx,0
mov cx,8
s: push [bx]
add bx,2
loop s
mov bx,0
mov cx,8
s0: pop [bx]
add bx,2
loop s0
mov ax,4c00h
int 21h
code ends
end start
定义多个段要注意的地方:
- 不同的段,不同的标号。
- 对段地址的引用,段地址标号就是一个数值,不能赋给段寄存器。
- 尽管我们明明assume cs:code,ds:data,ss:stack. data segment 、stack segment 、code segment,但实际上还是需要我们自己去给地址 。mov ax,stack, mov ss,ax、mov ax,data, mov ds,ax。。。。。。
- assume 只知道需要它将定义的具有一定用途的段和相关的和寄存器联系起来就好了。
实验5 编写、调试具有多个段的程序
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
- 23 01 56 04 89 07 bc 0a-ef 0d ed 0f ba 0c 87 09
- cs = 076ch ss = 076bh ds = 076ah
- code = x ,data = x-2 ,stack = x-1
(2)
assume cs:code ,ds:data,ss:stack
data segment
dw 0123h ,0456h
data ends
stack segment
dw 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
- 21 01 56 04
- cs=076c ss=076b ds=076a
- code = x, data = x-2 , stack = x-1
- (N/16 + 1)*16 因为每次分配16的整数倍。
assume cs:code ,ds:data, ss:stack
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
data segment
dw 0123h, 0456h
data ends
stack segment
dw 0, 0
stack ends
end start
- 23 01 56 04
- cs = 076ch, ss = 076bh, ds = 075ah
- code的字节为32,data的字节为4,stack的字节为4,按照(N/16+1)计算code 距离3,stack距离data1,距离code4 。[1] code = X data = X+3 , stack = X+4 ,
code ;X
32字节 -> 3
data ;X+3
4字节 -> 1
stack ;X+4
4字节 -> 1
- 只有第3个可以正常运行。是因为第三个程序前面不存在数据。可以直接从头运行。
assume cs:code
a segment
db 1,2,3,4,5,6,7,8
a ends
b segment
db 1,2,3,4,5,6,7,8
b ends
c segment
db 0,0,0,0,0,0,0,0
c ends
code segment
start:
mov bx,0
mov cx,8
j: mov ax,a
mov ds,ax
mov dl,[bx]
mov ax,b
mov ds,ax
add dl,[bx]
mov ax,c
mov ds,ax
mov [bx],dl
inc bx
loop j
mov ax,4c00h
int 21h
code ends
end start
(6)
assume cs:code
a segment
dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0dh,0eh,0fh,0ffh
a ends
b segment
dw 0,0,0,0, 0,0,0,0
b ends
code segment
start: mov ax,a
mov ds,ax
mov ax,b
mov ss,ax
mov sp,16
mov bx,0
mov cx,8
s: push [bx]
add bx,2
loop s
mov ax,4c00h
int 21h
code ends
end start