1.程序取得所需空间的两种方法:加载程序的时候系统分配和程序在执行的过程中向系统申请。
2.从规范的角度讲,我们不能随便决定哪段空间可以使用,应该让系统为我们分配;
3.DW的含义是定义字型数据,所占内存大小为16个字节;
4.假设dw在一个程序的开始定义了8个数据,那么这8个数据的地址在代码段的偏移分别是0,2,4,6,8,a,c,e处,对应的地址是cs:0,cs:2,cs:4,...cs:e等;
5.一般情况下我们将程序加入内存的时候系统会自动分配给我们一个段来存放这个程序,因此我们用debug查看的时候DS=XXXX,后面的数值给出我们这段程序开始的段地址;
6.在程序的第一条指令前面加上一个标号start,然后这个标号在end后面出现。这样可以让编译器知道我们程序的入口在什么地方,这里end多了另外一个作用,通知编译器程序入口在什么地方;
7.将程序,代码放入不同段:
(1)把他们放到一个段中使程序显得混乱;
(2)前面程序中处理的数据很少,用到的栈空间也少,加上没有多长的代码放到一个段里面没有问题。但是如果数据,栈和代码需要的空间超过了64k,就不能放在一个段中了;
8.受8086cpu的限制,一个段的容量不能大于64k,但是不是所有的cpu都是这个样子的;
9.对于不同的段,要有不同的段名,对于段地址的引用一般是段名加上该数据在段中的偏移地址;

检测点6.1
(1) 下面的程序实现依次用内存0:0~0:15单元中的内容改写程序中的数据,完成程序:assume cs:codesg
codesg segment
    dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
start: mov ax,0
    mov ds,ax
    mov bx,0
    mov cx,8
s: mov ax,[bx]
    mov cs:[bx],ax
    add bx,2
    loop s
    mov ax,4c00h
    int 21h
codesg ends
end start
(2) 下面的程序实现依次用内存0:0~0:15单元中的内容改写程序中的数据,数据的传送用栈来进行。栈空间设置在程序内。完成程序:
assume cs:codesg
codesg segment
    dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
    dw 0,0,0,0,0,0,0,0,0,0         ;10个字单元用栈空间
start:
    mov ax,cs   
    mov ss,ax
    mov sp,36
    mov ax,0
    mov ds,ax
    mov bx,0
    mov cx,8
s:
    push [bx]
    pop cs:[bx]
    add bx,2
    loop s
  
    mov ax,4c00h
    int 21h
codesg ends
end start

实验5 编写、调试具有多个段的程序
(1) 将下面的程序编译连接,用Debug加载、跟踪,然后回答问题assume cs:code,ds:data,ss:stack
data segment  
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987hdata 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
① CPU执行程序,程序返回前,data段中的数据为多少?   解:不变
② CPU执行程序,程序返回前,cs=155ch、ss=155bh、ds=155ah。 (此题结果因环境而异,但相对差值不变)
③ 设程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。
(2) 将下面的程序编译连接,用Debug加载、跟踪,然后回答问题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
① CPU执行程序,程序返回前,data段中的数据为多少?   解:不变
② CPU执行程序,程序返回前,cs=155ch、ss=155bh、ds=155ah。 (此题结果因环境而异,但相对差值不变)
③ 设程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。
④对于如下定义的段:
name segment…name ends
如果段中的数据占N个字节,则程序加载后,这段实际占有的空间为(N/16+1)*16.     (N/16为取整数部分)
(3) 将下面的程序编译连接,用Debug加载、跟踪,然后回答问题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
① CPU执行程序,程序返回前,data段中的数据为多少?   解:不变
② CPU执行程序,程序返回前,cs=155ah、ss=155eh、ds=155dh。 (此题结果因环境而异,但相对差值不变)
③ 设程序加载后,code段的段地址为X,则data段的段地址为X+3,stack段的段地址为X+4。
(4) 如果将(1)、(2)、(3)题中的最后一条伪指令“end start”改为“end”(也就是说不指明程序的入口),则那个程序仍然可以正确执行?请说明原因。
解:都能正常运行。如果不指明程序的入口,编译器自动默认代码段的第一条指令为程序的入口。
(5) 程序如下,编写code段中的内容,将a段和b段中的数据依次相加,将结果存到c段中。
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 ax,a
mov ds,ax
mov bx,0
mov cx,8
s:mov al,ds:[bx]
add al,ds:[bx+16]//不够16个字节的安16个字节来算
mov ds:[bx+32],al
inc bx
loop s
mov ax,4c00h
int 21h
code ends
end start
(5) 程序如下,编写code段中的内容,将a段和b段中的数据依次相加,将结果存到c段中。
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 ax,amov ds,axmov bx,0
mov cx,8s:mov al,ds:[bx]add al,ds:[bx+16]mov ds:[bx+32],alinc bxloop s
mov ax,4c00hint 21h
code ends
end start
(6) 程序如下,编写code段中的代码,用push指令将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
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 bx,0
mov ax,b
mov ss,ax
mov sp,16
mov cx,8
s:push [bx]
inc bx
inc bx
loop s
mov ax,4c00h
int 21h
code ends
end start