匯編語言編程編程練習(xí)

匯編語言編程編程練習(xí)

ID:38716934

大小:65.50 KB

頁數(shù):12頁

時間:2019-06-18

匯編語言編程編程練習(xí)_第1頁
匯編語言編程編程練習(xí)_第2頁
匯編語言編程編程練習(xí)_第3頁
匯編語言編程編程練習(xí)_第4頁
匯編語言編程編程練習(xí)_第5頁
資源描述:

《匯編語言編程編程練習(xí)》由會員上傳分享,免費在線閱讀,更多相關(guān)內(nèi)容在教育資源-天天文庫。

1、匯編語言編程編程練習(xí)一、實驗題1.非數(shù)值運算編程(a)實驗?zāi)康耐ㄟ^非數(shù)值運算(如統(tǒng)計,分類,排序,代碼轉(zhuǎn)換等)編程,進一步掌握8086/8088匯編語言程序設(shè)計方法和技巧(b)實驗內(nèi)容·統(tǒng)計設(shè)有100H個數(shù),編程統(tǒng)計正數(shù)、負數(shù)和零的個數(shù)。實驗分析:程序中數(shù)的總數(shù)很多,某些部分需要重復(fù)執(zhí)行,因此要用到循環(huán)結(jié)構(gòu)。循環(huán)結(jié)構(gòu)每次測試循環(huán)條件,當(dāng)滿足條件時,重復(fù)執(zhí)行這一段程序;否則循環(huán)結(jié)束,順序往下執(zhí)行。其次,要統(tǒng)計正數(shù)、負數(shù)、零的個數(shù),可以依靠標志位SF進行判斷,SF=0,正數(shù);SF=1,負數(shù);零則為總數(shù)減去正負數(shù)的個數(shù)。該程序流程圖如下:修改

2、:移動緩沖區(qū)指針,循環(huán)次數(shù)減一執(zhí)行:從BUFF取數(shù),進行算術(shù)運算,判斷符號標志位SF初始化:設(shè)置緩沖區(qū)BUFF指針BX,設(shè)定循環(huán)次數(shù)256,統(tǒng)計計數(shù)器DL清零開始循環(huán)控制:CX=0NOYES結(jié)束:將寄存器的統(tǒng)計結(jié)果存入MEM單元,將控制交操作系統(tǒng)程序如下所示:STACKSEGMENTSTACKDW128DUP(?)STACKENDSDATASEGMENTBUFFDB256DUP(?)MEM1DB?MEM2DB?MEM3DB?DATAENDSCODESEGMENTASSUMECS:CODE,DS:DATASTART:MOVAX,DATAM

3、OVDS,AXMOVCX,256LEABX,BUFFXORDL,DLXORDH,DHXORSI,SI;統(tǒng)計計數(shù)器清0NEXT:MOVAL,[BX];取數(shù)據(jù)到ALADDAL,0;做運算,影響標志位SFJNSAA1;是正數(shù),跳到AA1INCDL;是負數(shù),統(tǒng)計加1AA1:INCDH;是正數(shù),加1INCBX;移動指針LOOPNEXT;循環(huán)控制MOVMEM1,DLMOVMEM2,DHMOVMEM3,SI;保存統(tǒng)計結(jié)果MOVAX,4C00HINT21HCODEENDSENDSTART·代碼轉(zhuǎn)換編程將組合的BCD碼9649轉(zhuǎn)換成二進制數(shù),考慮采用((

4、(A*10)+B)*10)+C)*10+D的算法。實驗分析:由學(xué)習(xí)已知,寫成十六進制的BCD碼和十進制碼是完全一樣的,比如,75D=(01110101)BCD,而(01110101)B=75H。BCD碼的運算也遵循十進制運算規(guī)則,這一點可以方便計算機本身擅長的二進制運算結(jié)合BCD碼的調(diào)整指令來完成。本題中,由于9469H計算機會默認為二進制數(shù)。因而,我們首先要做的是將9469hBCD碼先轉(zhuǎn)換成十進制數(shù),計算機將會以二進制形式存儲。最后再輔助程序令其輸出在屏幕上。實驗大抵流程如下:開始初始化:設(shè)定字節(jié)空間……執(zhí)行:BCD碼轉(zhuǎn)化成十進制二進

5、制碼輸出結(jié)束實驗代碼如下:DATASSEGMENTbuffer1DW9649hbuffer2DW?;分配兩個字節(jié)的空間DATASENDSCODESSEGMENTASSUMECS:CODES,DS:DATASSTART:MOVAX,DATASMOVDS,AXmovax,[buffer1]andax,0f000hmovcl,12shrax,clmovdx,ax;至此,已將9649h(BCD)中的9(十進制)取出,并放入dx中callchange;調(diào)用chang,將9乘以10movax,dxmovbx,[buffer1]andbx,0f00h

6、movcl,8shrbx,claddax,bxmovdx,axcallchangemovax,dxmovbx,[buffer1]andbx,00f0hmovcl,4shrbx,claddax,bxmovdx,axcallchangemovax,dxmovbx,[buffer1]andbx,000fhaddax,bx;至此,ax中的值已是9649(十進制),但電腦是將其以二進制的形式存儲的,故應(yīng)是25B1h,二進制就是0010010110110001movbuffer2,ax;因為后面會用到ah,為避免在其過程中丟失ax中的數(shù)據(jù),故將ax

7、中的數(shù)據(jù)放入buffer2中movcx,16again:shlbuffer2,1;將已經(jīng)轉(zhuǎn)換成二進制的數(shù)逐個顯示出來movdl,0adcdl,30hmovah,2int21hloopagainmovah,4CHINT21Hchangeproc;子程序change的功能是實現(xiàn)dx乘以10adddx,dxmovcx,dxadddx,dxadddx,dxadddx,cxretchangeENDPCODESENDSENDSTART·排序?qū)?0H個無符號的八位二進制數(shù)按遞增方式排列。同時考慮它們有符號數(shù)、遞減等方式。實驗分析:實驗要求將數(shù)排序,則

8、用CMP比較兩個數(shù)大小,用標志位JNG(有符號位不大于),JGE(有符號位不小于),JAE(無符號位不低于)來判定排序種類。準備將該題用“冒泡排序法”,將其兩兩比較。前一個數(shù)較大(遞減),則不會改變原來位置

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當(dāng)前文檔最多預(yù)覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學(xué)公式或PPT動畫的文件,查看預(yù)覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫負責(zé)整理代發(fā)布。如果您對本文檔版權(quán)有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內(nèi)容,確認文檔內(nèi)容符合您的需求后進行下載,若出現(xiàn)內(nèi)容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網(wǎng)絡(luò)波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。