实验四 [bx]和loop的使用+段前缀
[bx]和loop的使用
(1)編程,向內(nèi)存0:200~0:23F依次傳送數(shù)據(jù)0 ~63(3FH)
(2)編程,向內(nèi)存0:200~0:23F依次傳送數(shù)據(jù)0 ~63(3FH),程序中只能使用9條指令,9條指令中包括"mov ax,4c00h"和"int 21h"。
assume cs:code code segmentmov ax,20Hmov es,ax;數(shù)據(jù)傳到哪里去mov cx,64mov bx,0mov dl,0 ;邏輯清晰loop setnumber:mov es:[bx],bl ;把dl也省了inc bx ;increase自增loop setnumbermov ax,4c00hint 21h code ends end(3)下面的程序的功能是將“mov ax,4c00h”之前的指令復(fù)制到0:200處,補(bǔ)全程序。上機(jī)調(diào)試,跟蹤運(yùn)行結(jié)果。
比較以下匯編源程序中以下指令的含義
mov al,[0] ——》 含義:(al)=0,將常量0送入al中,與mov al,0含義相同
mov al,ds:[0] ——》 含義:(al)=((ds)*16+0),將內(nèi)存單元中的數(shù)據(jù)送入al中
mov al,[bx] ——》 含義:(al)=((ds)*16+【bx】),將內(nèi)存單元中的數(shù)據(jù)送入al
mov al,ds:[bx] ——》含義:與“mov al,【bx】”相同
從上面的比較中可以看出
(1)在匯編源程序中,如果用指令訪問一個(gè)內(nèi)存單元,則在指令中必須用“[…]”來表示內(nèi)存單元,如果在“[ ]”里用一個(gè)常量idata直接給出內(nèi)存單元的偏移地址,就要在“[ ]”的前面顯示地給出段地址所在的段寄存器。比如 mov al,ds:[0]
如果沒有在“【】”的前面顯示地給出段地址所在的段寄存器,比如
mov al,【0】
那么編譯器masm把指令【idata】理解為idata。
(2)如果在“【】”中用寄存器,比如bx,間接給出內(nèi)存單元的偏移地址,則段地址默認(rèn)在ds中。當(dāng)然也可以顯式地給出段地址所在的段寄存器。
段前綴
指令“mov ax,[bx]”中,內(nèi)存單元的偏移地址由bx給出,而段地址默認(rèn)在ds。我們可以在訪問內(nèi)存單元的指令中顯式地給出內(nèi)存單元的段地址所在的段寄存器。比如:
(1)mov ax,ds:[bx]
將一個(gè)內(nèi)存單元的內(nèi)容送入ax,這個(gè)內(nèi)存單元的長度為兩個(gè)字節(jié),存放一個(gè)字,偏移地址在bx中,段地址在ds中。
(2)mov ax,cs:[bx]
將一個(gè)內(nèi)存單元的內(nèi)容送入ax,這個(gè)內(nèi)存單元的長度為兩個(gè)字節(jié),存放一個(gè)字,偏移地址在bx中,段地址在cs中。
(3)mov ax,ss:[bx]
將一個(gè)內(nèi)存單元的內(nèi)容送入ax,這個(gè)內(nèi)存單元的長度為兩個(gè)字節(jié),存放一個(gè)字,偏移地址在bx中,段地址在ss中。
(4)mov ax,es:[bx]
將一個(gè)內(nèi)存單元的內(nèi)容送入ax,這個(gè)內(nèi)存單元的長度為兩個(gè)字節(jié),存放一個(gè)字,偏移地址在bx中,段地址在es中。
(5)mov ax,ss:[0]
將一個(gè)內(nèi)存單元的內(nèi)容送入ax,這個(gè)內(nèi)存單元的長度為兩個(gè)字節(jié),存放一個(gè)字,偏移地址為0,段地址在ss中。
(6)mov ax,cs:[0]
將一個(gè)內(nèi)存單元的內(nèi)容送入ax,這個(gè)內(nèi)存單元的長度為兩個(gè)字節(jié),存放一個(gè)字,偏移地址為0,段地址在cs中。
用于顯式地指明內(nèi)存單元段地址的“ds:”,“cs:”,“ss:”,“es:”,在匯編語言中稱為段前綴。
總結(jié)
以上是生活随笔為你收集整理的实验四 [bx]和loop的使用+段前缀的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何使柱状图左右展示_Excel多次层柱
- 下一篇: 数据异常HTML,@ Html.Drop