




版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
2023/2/51/41第7章匯編語言程序設計7.1程序設計步驟7.2簡單程序7.3分支程序7.4循環(huán)程序7.5子程序習題7.1程序設計步驟2023/2/52/41匯編語言程序設計步驟:
(1)分析問題:已知條件、要解決的問題、功能/性能要求等。
(2)建立數(shù)學模型:把問題數(shù)學化、公式化,便于計算機處理。
(3)確定算法:簡單、速度快、精度高、代碼量小、編程容易。
(4)繪制程序流程圖:用箭頭、框圖、菱形圖等表示程序結構。
(5)內存空間分配:為程序或數(shù)據(jù)分配內存空間。
(6)編制程序與靜態(tài)檢查:程序結構層次簡單、清楚、易懂。
(7)程序調試:利用調試軟件DEBUG進行調試。2023/2/53/41匯編語言程序設計的特點:
(1)算法要分解至指令級;高級語言為語句級。
(2)要詳細考慮內存空間分配問題:
任何一個變量、一條指令都要明確其存儲位置7.2簡單程序
這種程序的形式最簡單,計算機執(zhí)行程序的方式是“從頭到尾”,逐條執(zhí)行指令語句,直到程序結束。這類簡單程序不用按上述7個步驟,可直接對給出的題目寫出助記符程序清單?!纠?.1】用數(shù)據(jù)運算指令,對兩個16位數(shù)做加法運算。這兩個數(shù)從地址10050H開始連續(xù)存放,低位在小地址一端,結果放在這兩個數(shù)之后。(1)分析題目:它是一個16位數(shù)相加的問題。在用加法指令時,必須要考慮低8位和低8位相加后產(chǎn)生的進位問題。2023/2/54/412023/2/55/41(2)根據(jù)86系列指令系統(tǒng),可以直接對累加器AX做字操作,但在低位相加后,會影響標志寄存器的進位CF,所以,要用帶進位的加法指令。(3)繪制程序流程圖,如右圖所示。簡單程序框圖(雙字節(jié)相加)2023/2/56/41(4)內存空間分配:被加數(shù)、加數(shù)及和在內存的空間分配見下表內存地址內容10050H被加數(shù)低8位10051H被加數(shù)高8位10052H加數(shù)低8位10053H加數(shù)高8位10054H和的低8位10055H和的高8位雙字節(jié)相加時的內存分配2023/2/57/4150H51H52H53H54H55H12H34HA1HBDHAX00H10H50H51H52H53H54H55HAX12H34HAXB3HF1HDIA1HBDH+=內存地址存儲內容MOVAX,1000HMOVDS,AXMOVSI,50HMOVDI,52HMOVBX,54HSIDIBX50H51H52H53H54H55H12H34HA1HBDHB3HF1HBXB3HF1H低位在前,高位在后CLCXORAX,AXMOVAX,[SI]ADCAX,[DI]MOV[BX],AXHLT設SI=3412HDI=BDA1H內存分配示意程序詳細注釋見下頁
2023/2/58/41(5)編制的程序如下:MOV
AX,1000H
MOV
DS,AX;DS=1000H
MOV
SI,50H;被加數(shù)指針SI=50H
MOV
DI,52H;加數(shù)指針DI=52H
MOV
BX,54H;和的指針BX=54H
CLC;
清CF
XOR
AX,AX;清AX異或
MOV
AX,[SI];取一個字到AX
ADC
AX,[DI];AX←AX+[DI]+CF
MOV[BX],AX;存一個字到[BX]HLT;暫停查看程序問題:該程序能否簡化?如何簡化?2023/2/59/41簡化的程序:MOV
AX,1000H
MOV
DS,AX;DS=1000H
MOV
AX,[50H];取被加數(shù)到AXADC
AX,[52H];AX←被加數(shù)+加數(shù)MOV[54H],AX;存和數(shù)到[54H]HLT;暫停2023/2/510/41
【例7.2】將內存(10050)單元的內容(7AH)拆成兩段,每段4位,并將它們分別存入內存(10051)和(10052)單元。即(10050)單元中的低4位放入(10051)的低4位,(10050)單元中的高4位放入(10052)的低4位,而(10051)和(10052)的高4位均為零。(1)分析題目:這個題目提出的任務在十六進制顯示及二、十進制計算中常遇到的.現(xiàn)在假設內存(10050)中放著7AH,則題目要求就是把7AH拆成07H和0AH兩部分,并把0AH放在(10051)單元,07H放在(10052)單元。2023/2/511/41
在拆字時,想取得一個數(shù)的前4位和后4位可以用移位指令的方法,也可以用邏輯“與”一個0F0H(二進制為11110000)和邏輯“與”一個0FH(二進制為00001111)的辦法。(2)根據(jù)指令系統(tǒng)中含有的指令,先取出該數(shù)用邏輯指令與上一個0FH,得到低4位,存入內存。再取出該數(shù)用移位指令邏輯右移SHR4次,取得高4位,存入內存即可。2023/2/512/41(3)繪制程序流程圖,如圖所示。(4)內存空間分配:把7AH拆成07H和0AH兩部分,它們在內存空間的分配情況見下頁表。拆字程序框圖2023/2/513/41內存分配示意圖10050H7AH7HAH0H10051H0H10052H拆開AH7AHAH7AHAH7AHAH7H內存地址內容10050H7AH10051H0AH10052H07H拆字程序的內存分配2023/2/514/41(5)編制的程序如下:MOVAX,1000HMOVDS,AX;DS=1000HMOVSI,50H;需拆字節(jié)的指針SI=50HMOVAL,[SI];取一個字節(jié)到AL中ANDAL,0FH;把AL的前4位清0MOV[SI+1],AL;把得到的后4位放到(10051)單元MOVAL,[SI];再取出需拆字節(jié)放到AL中MOVCL,4SHRAL,CL;邏輯右移四次,前4位補0MOV[SI+2],AL;放入(10052)單元查看程序2023/2/515/41[例3]編程計算1+2+3+4。MOVAX,0ADDAX
,1ADDAX
,2ADDAX
,3ADDAX
,4初始化:AX0開始
AXAX+1
AXAX+2結束
AXAX+3
AXAX+4分析:需要有一個暫存空間存放累加和,初值設置為0,之后依次累加。2023/2/516/41練習:
將數(shù)據(jù)1A2BH,1200H,339AH,1200H分別存入相鄰的內存單元中,然后將前三個數(shù)相加并減去第四個數(shù),最后將結果傳遞到相近的內存單元中。7.3分支程序2023/2/517/41分支程序是利用條件轉移指令實現(xiàn)程序執(zhí)行次序改變的一種程序結構形式,即當程序執(zhí)行到某一指令后,根據(jù)某個條件是否滿足,分別執(zhí)行不同的指令序列。一般來說,分支程序經(jīng)常是先用比較指令或數(shù)據(jù)操作及位檢測指令等來改變標志寄存器各個標志位。然后用條件轉移指令進行分支。分支程序執(zhí)行完后可以立即結束,也可以轉到公共點結束。分支程序可以再分支。程序框圖:在繪制程序流程圖時,需用菱形判斷框,表示判定條件。在繪制好流程圖編寫助記符程序時,建議先按上下流程線寫,寫完上下流程線上的各框環(huán)節(jié)后,再寫分支部分里的框框。2023/2/518/41
【例7.3】求AX累加器和BX寄存器中兩個無符號數(shù)之差的絕對值,結果放在內存(2800)單元中。(1)分析題目:此題目中,AX累加器和BX寄存器中的數(shù)是不知道的。對兩個不知大小的數(shù)相減并求絕對值,顯然應該先解決哪一個值稍大些,然后再用大數(shù)減小數(shù)的方法,才可求得絕對值。2023/2/519/41(2)根據(jù)指令系統(tǒng)中的比較指令,編出判斷大小的環(huán)節(jié),即可解決問題,下圖即為該例題的程序流程圖。求絕對值程序流程圖JC=JumpifCarry當運算產(chǎn)生進位標志時,即CF=1時,跳轉到目標程序處。(3)根據(jù)流程圖編制程序如下:
CLC;清除CF
SUB
AX,BX
JC
AA;CF=1轉AA去執(zhí)行(即AX<BX時轉移
MOV
DI,2800H;結果指針DI=2800H
MOV[DI],AX;結果送到2800H和2801H單元
HLT;暫停AA:
SUB
BX,AX;BX←BX-AX
MOV
DI,2800H
MOV[DI],BX
HLTSUBBX,AX2023/2/520/41
問題:這段程序有無錯誤?如果有錯,如何改正?CMP
AX,BXSUB
AX,BX2023/2/521/41【例7.4】編一個程序,從外設71H號中取一個數(shù)M,判斷其值是否在10和20之間,即10≤M<20。如果M≥20H,則送0FFH給外設73H;如果M<10,則送00H給外設73H;如果10≤M<20,則送88H給外設73H。(1)分析題目:根據(jù)題意,這是一個需要兩次判斷M大小的問題。先判M是否大于10,再判M是否大于20。2023/2/522/41(2)根據(jù)解決問題的思路,先畫出程序流程圖,如圖。
從圖的程序流程圖看,兩個分支都要“回歸”原程序。判斷M的兩分支流程圖2023/2/523/41
(3)編制的程序如下:START:IN
AL,71H;將71H端口的字節(jié)讀入AL
CLC;清除CF
CMP
AL,10;將AL的內容和10相比較
JC
LP1;小于10轉LP1
CMP
AL,20;將AL的內容和20相比較
JC
LP2;10≤AL<20轉LP2
MOV
BL,0FFH;將0FFH送入BL寄存器LP3:OUT
73H,BL;將0FFH輸出到73H端口
HLT;暫停LP1:MOV
BL,00
JMP
LP3LP2:MOV
BL,88H
JMP
LP3問題:這段程序有無錯誤?如果有錯,如何改正?MOVBL,ALBLBLALALALAL;無條件轉移START:IN
AL,71H;將71H端口的字節(jié)讀入ALMOVBL,AL
CLC;清除CF
CMP
BL,10;將BL的內容和10相比較
JC
LP1;小于10轉LP1
CMP
BL,20;將BL的內容和20相比較
JC
LP2;10≤BL<20轉LP2
MOV
AL,0FFH;將0FFH送入AL寄存器LP3:OUT
73H,AL;將0FFH輸出到73H端口
HLT;暫停LP1:MOV
AL,00
JMP
LP3LP2:MOV
AL,88H
JMP
LP32023/2/524/412023/2/525/41編一程序段,完成符號函數(shù):
1 X>0(-128≤X≤127)Y= 0 X=0 -1 X<0
假設X的值存放在DATA1中,
Y的值存放在DATA2中。練習2023/2/526/41練習題程序如下:START:MOVAL,DATA1 ANDAL,AL JGEBIGR MOVAL,0FFH MOVDATA2,AL;X<0,-1送DATA2 HLTBIGR:JEEQUL MOVAL,1 MOVDATA2,AL;X>0,+1送DATA2 HLTEQUL:MOVDATA2,AL;X=0,0送DATA2 HLT2023/2/527/41讀程序,問:本段程序的執(zhí)行結果是什么?
BEGIN:IN
AL,5FH
TEST
AL,80H
JZ
BRCH1
MOV
AH,0
JMP
STOPBRCH1:MOV
AH,0FFH
STOP:HLT;將5FH端口的字節(jié)讀入AL;如果AL的最高位為1,則ZF=0,否則ZF=1;當結果為零(即ZF=1)時,跳轉至BRCH1;將立即數(shù)零送AH;無條件轉移至STOP;將0FFH送AH
;暫停當AL的最高位為1時,AH=0;當AL的最高位為0時,AH=0FFH。2023/2/528/41
雙分支程序設計
實現(xiàn)雙分支程序設計要完成以下幾項工作:
1.產(chǎn)生條件:主要用“比較”、“測試”等指令產(chǎn)生條件;
2.測試條件、定向轉移:用條件轉移指令完成;
3.設置執(zhí)行標志(標號):給執(zhí)行程序段定義地址標號。7.4循環(huán)程序2023/2/529/41循環(huán)程序是強制CPU重復執(zhí)行某一指令序列(程序段)的一種程序結構形式。循環(huán)結構程序縮短了程序的長度、減少了占用的內存空間。循環(huán)程序并不簡化程序執(zhí)行過程,相反,由于增加了一些循環(huán)控制等環(huán)節(jié),總的程序執(zhí)行語句和時間會有所增加。循環(huán)程序一般由4部分組成:初始化、循環(huán)體、循環(huán)控制和循環(huán)結束處理。循環(huán)程序分為單循環(huán)和多重循環(huán),兩重以上循環(huán)稱為多重循環(huán)。內外循環(huán)不能交叉。2023/2/530/417.4循環(huán)程序循環(huán)程序各部分的內容(1)初始化
建立循環(huán)次數(shù)計數(shù)器,設定變量和存放數(shù)據(jù)的內存地址指針(常用間址方式)的初值等。(2)循環(huán)體
實現(xiàn)程序功能的、被重復執(zhí)行的指令序列。(3)循環(huán)控制
修改變量和地址指針,為下一次循環(huán)做準備;修改循環(huán)計數(shù)器或者判斷循環(huán)條件是否滿足,滿足則繼續(xù)循環(huán),否則結束循環(huán)。(4)結束處理
它主要用來分析和存放程序的結果。2023/2/531/41循環(huán)控制方式有多種,如計數(shù)控制、條件控制等。計數(shù)控制事先已知循環(huán)次數(shù),每次循環(huán)加或減計數(shù),通過對循環(huán)次數(shù)的判定來達到控制循環(huán)的目的;條件控制事先不知循環(huán)次數(shù),通過判定某種條件的真假來達到控制循環(huán)的目的。不管哪一種控制循環(huán)方式,最終都是要達到控制循環(huán)的目的。若考慮不周,會造成死循環(huán),對這一點要注意。循環(huán)可以用跳轉語句實現(xiàn),如JMP,JZ等;也可以用專用循環(huán)控制語句實現(xiàn),如LOOP、LOOPE/LOOPZ、LOOPNE/LOOPNZ。【例7.5】求兩個多字節(jié)數(shù)之和。這兩個數(shù)在10050H地址開始的內存單元中,連續(xù)存放,低位在小地址一端,結果放在這兩個數(shù)之后。設這兩個多字節(jié)數(shù)均為8個字節(jié)長。
程序流程圖如右圖所示。2023/2/532/41(1)分析題目:這是一個重復累加內存單元中數(shù)的問題,因此可以用循環(huán)程序形式解決。因為86系列指令系統(tǒng)可以16位處理,所以,循環(huán)次數(shù)是4次。2023/2/533/4112…57434…1存儲器SI10050DI10058++++BX100605598…單擊2023/2/534/41(3)編制的程序如下:START:MOV
AX,1000H
MOV
DS,AX;DS=1000H
MOV
SI,50H;第一個數(shù)指針SI=50H
MOV
DI,58H;第二個數(shù)指針DI=58H
MOV
BX,60H;結果指針BX=60H
MOV
CX,4;循環(huán)次數(shù)CX=4
CLC;清進位CF=0AA:MOV
AX,[SI];取一個字到AX
下頁續(xù)2023/2/535/41
ADC
AX,[DI];AX←AX+[DI]+CF
MOV[BX],AX;存一個字到[BX]
PUSHF;保護進位CF
ADD
SI,2;修改第一個數(shù)的地址指針SI←SI+2
ADD
DI,2;修改第二個數(shù)的地址指針DI←DI+2
ADD
BX,2;修改結果指針BX←BX+2
POPF;恢復標志寄存器
LOOP
AA;CX←CX-1,若CX≠0轉AA
HLT;CX=0,暫停結束2023/2/536/41
【例7.6】要求設計一個軟件延時程序,延時時間約1ms左右。(1)分析題目:此題是想讓計算機做一些無用的操作,來拖延時間。從指令手冊中查得各條指令所需的時間節(jié)拍,但一般一條指令執(zhí)行時間只有幾個時鐘周期,亦即只有幾個微秒,為了能用較少的指令來編較長時間的延時,采用循環(huán)程序結構.2023/2/537/41(2)程序流程圖如圖所示。延時的時間主要取決于循環(huán)體及循環(huán)次數(shù)。PUSHF和POPF指令分別為10和8個時鐘節(jié)拍,LOOPBX指令為3.4個時鐘節(jié)拍,即此循環(huán)體需要用10+8+3.4=21.4拍,而每個時鐘節(jié)拍是根據(jù)此系統(tǒng)的晶振頻率而定的。假設此系統(tǒng)用的是8MHz的晶振,則每個時鐘節(jié)拍需要0.125μs,因此可以根據(jù)下列公式算出循環(huán)次數(shù):
X=延時時間/一次循環(huán)時間=1ms/21.4×0.125μs≈374次換算成十六進制數(shù)為176H。2023/2/538/41延時1ms的程序流程圖延時1ms的程序流程圖2023/2/539/41(3)編制的程序如下:START:MOV
CX,176H;初始化,設定循環(huán)次數(shù)CX=374LP1:PUSHF;循環(huán)體
POPF
LOOP
LP1;CX←CX-1,若CX≠0轉
HLT;暫停對于上例,如果想再延長1000倍時間(即延時1s),可以采用雙循環(huán)的方法,如圖所示的程序流程圖。對應的程序如下:2023/2/540/41
MOV
BX,3E8H;BX←1000LP2:MOVCX,176HLP1:PUSHF
POPF延時1ms程序段
LOOPLP1
DEC
BX;BX←BX-1
JNZ
LP2;ZF=0時,轉至LP2,即BX≠0時轉
HLT;暫停此程序中內循環(huán)是1ms時間,而在外循環(huán)中的兩條控制指令DEC和JNZ所對應的時鐘節(jié)拍分別為2個和4個,一共只需0.75μs,與1ms比較極短,所以在外循環(huán)里忽略不計了,外循環(huán)的循環(huán)初值仍設為1000次,對應的十六進制為3E8H。例設AX寄存器中有一個16位二進制數(shù),編一程序,統(tǒng)計AX中‘1’的個數(shù),統(tǒng)計結果送CX中。該程序可用固定次數(shù)循環(huán)和條件判斷兩種方法實現(xiàn)。條件判斷法編制程序如下:START:MOVCX,0LOOP:SUB AX,0 JZ STP SAL AX,1 JNC NOD INC CXNOD:JMP LOOPSTP: HLT2023/2/541/41固定次數(shù)循環(huán)法,循環(huán)次數(shù)為16次,程序如下:其中:CX中存放循環(huán)次數(shù),BX中存放“1”的個數(shù).
MOVCX,16MOVBX,0AA:SHLAX,1JCYYJMPPPYY:INCBXPP:LOOPAAHLT例:計算S=1+2+3+……+100的和值并將其存入數(shù)據(jù)段[2000H]單元.2023/2/542/41程序如下:
MOVCX,0064H
MOVAL,0MOVBL,1AA:ADDAL,BLINCBLLOOPAAMOV[2000H],ALHLT例:讀程序,(1)本程序實現(xiàn)什么功能?(2)結果在哪里?2023/2/543/41START:IN
AL,20H
MOV
BL,AL
IN
AL,30H
MOV
CL,AL
MOV
AX,0ADLOP:ADD
AL,BL
ADC
AH,0
DEC
CL
JNZ
ADLOP
HLT
;將20H端口的字節(jié)讀入AL;AL中的8位字節(jié)送BL;將30H端口的字節(jié)讀入AL;AL中的8位字節(jié)送CL;立即數(shù)0送AX;AL與BL的內容相加,結果放AL;AH的內容與立即數(shù)0以及CF相加;CL內容減1,結果放CL;當結果不為零時,執(zhí)行ADLOP;暫停20H與30H端口的內容相乘,結果放在AX中447.5子程序和庫為了程序共享或模塊化設計的需要,可以把一段公共語句序列設計成子程序或宏指令的形式。45
當把一段可共享的語句序列組織成子程序后,一旦需要實現(xiàn)該功能,就由調用程序調用之,當子程序執(zhí)行結束后再返回到主程序繼續(xù)執(zhí)行。7.5.1子程序的定義
主程序子程序
主子程序關系示意圖①②③④46定義子程序的一般格式在匯編語言中用過程定義偽指令定義子程序。 過程名 PROC【類型】 …
過程名 ENDP477.5.1子程序的定義“子程序名”必須是一個合法的標識符,并前后二者要一致;PROC和ENDP必須是成對出現(xiàn)的關鍵字,表示子程序定義開始和結束;子程序的類型有近(NEAR)、遠(FAR)之分,其缺省的類型是近類型;NEAR類型的子程序只能被與其同段的程序所調用,F(xiàn)AR類型的子程序可被不同段的程序所調用;子程序至少要有一條返回指令。返回指令是子程序的出口語句,但它不一定是子程序的最后一條語句;子程序名有三個屬性:段值、偏移量和類型。其段值和偏移量對應于子程序的入口地址,其類型就是該子程序的類型。48
調用子程序指令格式如下:
CALL子程序名/Reg/Mem子程序的調用指令分為近(near)調用和遠(far)調用。如果被調用子程序的屬性是近的,那么,CALL指令將產(chǎn)生一個近調用,它把該指令之后地址的偏移量(用一個字來表示的)壓棧,把被調用子程序入口地址的偏移量送給指令指針寄存器IP即可實現(xiàn)執(zhí)行程序的轉移。7.2子程序的調用和返回指令49如果被調用子程序的屬性是遠的,那么,CALL指令將產(chǎn)生一個遠調用。這時,調用指令不僅要把該指令之后地址的偏移量壓進棧,而且也要把段寄存器CS的值壓進棧。在此之后,再把被調用子程序入口地址的偏移量和段值分別送給IP和CS,這樣完成了子程序的遠調用操作。例如:
CALLDISPLAY ;DISPLAY是子程序名
CALLBX ;BX的內容是子程序的偏移量
CALLWORD1 ;WORD1是內存字變量,其值是子程序的偏移量501.子程序調用指令
CALL
格式:CALLDST
功能:調用子程序。執(zhí)行時先把返回地址壓入堆棧,再形成子程序入口地址,最后把控制權交給子程序。 說明:其中DST為子程序名或子程序入口地址,其目標地址的形成與JMP指令類似,可以有段內直接/間接調用、段間直接/間接調用之分,只是不能使用段內直接尋址方式的SHORT格式。51⑴段內調用這類調用指令實現(xiàn)同一段內的子程序調用,它只改變IP值,不改變CS值。執(zhí)行操作:把返回地址(CALL之后的那條指令地址的偏移量部分(當前IP值))壓入堆棧。根據(jù)與轉移地址有關的尋址方式形成子程序入口地址的IP值。把控制無條件轉向子程序,即執(zhí)行CS:IP處的指令。52①段內直接調用:格式:CALLPROCEDURE或:CALLNEARPTRPROCEDURE功能:調用PROCEDURE子程序。執(zhí)行時先把返回地址壓入堆棧,再使IP=(IP)+disp16,最后把控制權交給子程序。說明:這種指令使用與轉移地址有關的尋址方式中的段內直接尋址方式。例1.
設子程序A與CALL指令在同一段內,則調用A子程序的指令是:
CALLA或:CALLNEARPTRA53②段內間接調用: 格式:CALLREG/M
功能:調用子程序。執(zhí)行時先把返回地址壓入堆棧,再把指令指定的16位通用寄存器或內存單元的內容送給IP,最后把控制權交給子程序。說明:這種指令使用與轉移地址有關的尋址方式中的段內間接尋址方式,指令指定的通用寄存器或內存單元中存放段內偏移量。54⑵段間調用
這類調用指令可以實現(xiàn)段間調用(FAR型調用),執(zhí)行時即要改變IP值,也要改變CS值。55①段間直接調用:
格式:CALLFARPTRPROCEDURE
功能:調用PROCEDURE子程序。執(zhí)行時先把返回地址(當前IP值和當前CS值)壓入堆棧,再把指令中的偏移量部分送給IP,段基址部分送給CS,最后把控制權交給子程序。
說明:這種指令使用與轉移地址有關的尋址方式中的段間直接尋址方式。
例3.
設子程序B與CALL指令不在同一段內,則段間直接調用B子程序的指令是:
CALLFARPTRB56②段間間接調用: 格式:CALLM
功能:調用子程序。執(zhí)行時先把返回地址(當前IP值和當前CS值)壓入堆棧,再把M的低字送給IP,高字送給CS,最后把控制權交給子程序。 說明:這種指令使用與轉移地址有關的尋址方式中的段間間接尋址方式,其中M為內存的雙字長地址指針,低字部分為16位的偏移量,高字部分為段基址。57
例4.
對于例3,若子程序B的入口地址(偏移量和段基址)放在變量VAR中,即可通過VAR實現(xiàn)段間間接調用。如下所示:
CALLDWORDPTRVAR ;從VAR變量中得到子程序B的入口地址實現(xiàn)調用 變量VAR的地址也可以通過寄存器間接尋址方式、基址變址尋址方式等存儲器操作數(shù)尋址方式得到。
例.CALLDWORDPTR8[BX][DI] 58
當子程序執(zhí)行完時,需要返回到調用它的程序之中。為了實現(xiàn)此功能,指令系統(tǒng)提供了一條專用的子程序返
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2824勞務用工合同范例
- 全款買房 合同范例
- 買房委托合同范例
- 個體鋪面出租合同范例
- 乙方樁基勞務合同范例
- 公司貨款欠款合同范本
- 住建部勘察合同范例
- 農(nóng)產(chǎn)品配送價格合同范例
- ppp總包合同范例
- 再管服務合同范本
- 2024年上海公安機關勤務輔警招聘筆試參考題庫附帶答案詳解
- 健康知識科普講座主題
- 籃球突分技術與配合-教學設計
- 【音樂】歌唱祖國-《彩色的中國》課件 2023-2024學年人音版初中音樂七年級上冊
- 營區(qū)綠化方案
- JJF 2095-2024壓力數(shù)據(jù)采集儀校準規(guī)范
- 2023年上海市16區(qū)數(shù)學中考二模匯編2 方程與不等式(39題)含詳解
- 光伏并網(wǎng)前單位工程驗收報告-2023
- 《貝爾格里爾斯》課件
- 火鍋店消防知識培訓課件
- 直腸癌健康宣教
評論
0/150
提交評論