Assemble 實驗五

任務1:

彙編源代碼: 

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

  • CPU執行程序,程序返回前,data段的數據不變
  • CPU執行程序,程序返回前,cs=076C,ss=076B,ds=076A.
  • 設程序加載後,code段的段地址爲X,則data段的段地址爲X-2,stack段的短地址爲X-1。

任務二:

彙編源代碼:

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=076C,ss=076B,ds=076A.
  • 設程序加載後,code段的段地址爲X,則data段的段地址爲X-2,stack段的短地址爲X-1。

任務三:

彙編源代碼:

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=076C,ss=076B,ds=076A.
  • 設程序加載後,code段的段地址爲X,則data段的段地址爲X-2,stack段的短地址爲X-1。​​​​​​​

​​​​​​​任務四:若將1、2、3題中的最後一條僞指令"end start"改爲"end",則哪個程序仍然可以正確執行?請說明原因。

    我認爲只有第三個程序可以正確執行,start的作用相當於標號,方便程序員不用再去找實際代碼段中的內存地址,因此前兩個程序中,stack段和data段的設置都在code段之前,因此內存並不是從00開始所以當程序執行時若從偏移地址爲0處開始觀察,則無法觀察到想要的結果。

任務五:

彙編源代碼:

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

c1 segment  
  db 8 dup(0)
c1 ends	   
code segment
start:
  mov ax,a
  mov ds,ax
  mov ax,b
  mov ss,ax
  mov ax,c1
  mov es,ax
  mov cx,8
  mov bx,0

s:mov al,[bx]
  mov ah,0
  mov dl,ss:[bx]
  mov dh,0
  add al,dl
  mov es:[bx],al
  inc bx
  loop s

  mov ax,4c00h
  int 21h    	
code ends
end start


計算結果:

任務六:

彙編源代碼:

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 8 dup(0)
b ends

code segment
start: 
  mov ax,a
  mov ds,ax
  mov ax,b
  mov ss,ax
  mov sp,16
  mov cx,8
  mov bx,0

s:mov ax,[bx]
  push ax
  add bx,2
  loop s

  mov ax,4c00h
  int 21h
code ends
end start

實驗結果:

實現了前八個字型數據的逆序相加。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章