碼制轉換十二進制數(shù)ASCII碼之間的互相轉換BCD_第1頁
碼制轉換十二進制數(shù)ASCII碼之間的互相轉換BCD_第2頁
碼制轉換十二進制數(shù)ASCII碼之間的互相轉換BCD_第3頁
碼制轉換十二進制數(shù)ASCII碼之間的互相轉換BCD_第4頁
碼制轉換十二進制數(shù)ASCII碼之間的互相轉換BCD_第5頁
已閱讀5頁,還剩26頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、1.碼制轉換 十、二進制數(shù)、ASCII碼之間的互相轉換。BCD數(shù)2進制數(shù) 算法:Dn-1*10n-1+D0*100 = (Dn-1*10+ Dn-2)*10+)*10+ D0 = (0*10+Dn-1)*10+ Dn-2)*10+)*10+ D0 即: 新的中間結果 = 中間結果*10+本位數(shù)字 (中間結果初值為0)4.5 常見程序設計舉例1程序1:將65535的非壓縮BCD數(shù)轉換成2進制數(shù)。程序如下。 ;數(shù)據(jù)段定義 mydata SEGMENT decnum DB 5, 3, 0, 1, 9 ;BCD數(shù) 53019 binnum DW ?mydata ENDS2prog SEGMENT AS

2、SUME CS:prog,DS:mydatabegin: MOV AX, mydata MOV DS, AX MOV SI, OFFSET decnum MOV CX, 5 ;5位BCD數(shù) MOV BX, 10 XOR AX, AX ;中間結果初始值為0Next: MUL BX ;中間結果*10+本位數(shù)字 ADD AL, SI ADC AH, 0 INC SI ;指向下位BCD數(shù) LOOP next MOV binnum, AX ;保存結果 MOV AH, 4CH INT 21Hprog ENDS END begin3程序2:把255的非壓縮BCD數(shù)轉換成2進制數(shù) decnum DB 1,5,

3、9 ;BCD數(shù)159 binnum DB ? MOV AX,decnum XCHG AH, AL ;百位在AH, 十位在AL AAD ;百位數(shù)*10 + 十位數(shù) MOV AH, AL ;中間結果送AH MOV AL, decnum+2 AAD ;中間結果*10 + 個位數(shù) MOV binnum, AL 4例:從鍵盤輸入兩個整數(shù),并求其和。 因鍵入為整數(shù),故要進行如下轉換: ASCIIBCD二進制數(shù) ASCIIBCD碼很簡單,高4位清零即可得到非壓縮的BCD碼。 BCD二進制數(shù)在本例中采用用以下方法: (0+千位數(shù))*10+百位數(shù))*10)+十位數(shù))*10+個位數(shù) ASCII碼二進制數(shù)(用于輸入

4、) 第一次中間結果第二次中間結果第三次中間結果最終結果5開始兩個數(shù)分別轉換成二進制數(shù)鍵入兩個數(shù)相加結束返回DOS如有溢出則提示開始取第一個ASCII碼是負號嗎?數(shù)字符個數(shù)1,指針1指針定位字符個數(shù)1= 0?取數(shù)字,與中間結果相加,再乘以10指向下一個數(shù)字字符加個位數(shù)是負數(shù)則求補存結果結束NYYN轉換子程序6程序如下:DATASEGMENTSTR1DB 10,?,10 DUP(?) ;第1個數(shù)的輸入緩沖區(qū)STR2DB 10,?,10 DUP(?) ;第2個數(shù)的輸入緩沖區(qū)NUMDW ?,? ;存轉換后的二進制數(shù)SUMDW 0 ;存和OVERDB Overflow!,13,10,$DATAENDS;

5、CODESEGMENTASSUME CS:CODE,DS:DATAMAINPROCFAR7START: MOVAX,DATAMOVDS,AXMOVAH,0AHLEADX,STR1INT21H ;輸入第一個數(shù)字串(設為26)MOVAH,0AHLEADX,STR2INT21H ;輸入第二個數(shù)字串(設為33)LEABX,STR1 ;串1的首地址送BXLEADI,NUM ;存二進制首地址送DI CALLCHANGE ;將串1 ASCII碼二進制 LEABX,STR2 ;串2的首地址送BX 8LEADI,NUM+2;指向CALLCHANGE;將串2 ASCII碼二進制MOVAX,NUM ;(AX)=NU

6、M=001AH ADDAX,NUM+2;兩數(shù)相加,(AX)=003BHMOVSUM,AX;存和JNONEXT;無溢出,轉NEXTLEADX,OVERMOVAH,9INT21H;顯示Overflow!NEXT:MOVAH,4CHINT21H;返回DOS MAINENDP9CHANGEPROCMOVCL,BX+1;實際字符數(shù)送CLMOVAL,BX+2;第一個字符送ALMOVCH,AL;暫存在CHCMPAL,-;第一個字符是負號嗎?JNZNEXT1;不是,轉NEXT1DECCL;字符數(shù)減1INCBXNEXT1: ADDBX,2;指向第一個數(shù)字字符MOVAX,0;清零AX,存二進制數(shù)LP1: DECC

7、LJZNEXT2;若(CL)=0,轉NEXT2MOVDL,BX ;取字符ANDDL,0FH;轉換成BCD碼 ADD AL,DL ;加到中間結果上 ADC AH,010 MOV DX,10 MUL DX ;*10 INC BX ;指向下一個字符 JMP SHORT LP1NEXT2: MOV DL,BX ;取個位數(shù) AND DL,0FH ;個位ASCII未組合BCD ADD AX,DX ;加個位數(shù),(AX)=001AH CMP CH,- ;是-? JNZ NEXT3 ;該數(shù)非負,轉NEXT3 NEG AX ;若為負,求補NEXT3: MOV DI,AX ;存二進制結果 RETCHANGE END

8、P;CODE ENDS END START11020A32360D020A33330D001A21003B00STR1STR2NUMSUM10個10個OOVER?040A313234STR1若鍵入 1234330D1234設鍵入第1個數(shù)為26, 第2個數(shù)為33,則在內(nèi)存各變量分配如下:12本例題重點掌握:如何從鍵盤輸入一個字符串ASCII未組合BCD二進制有符號數(shù)的運算,對負數(shù)和溢出如何處理思考題: 若鍵入第一個數(shù)26,第二個數(shù)為-4,填寫各變量結果。13方法1 計算二進制數(shù)中所包含的1000的個數(shù)、100的個數(shù)、10的個數(shù)和1的個數(shù)。方法2 除10取余。下面舉例介紹第一種方法。流程圖如下:二

9、進制數(shù)BCD14 YN二進制數(shù)AX令(DL)0(AX)-10000?(DL)+1(AX)+1000(AX)DL存至緩沖區(qū)令(DL)0YN(AX)-100?(DL)+1(AX)+10(AX)存DL存AL返回DOS求100的個數(shù),結構同上A15匯編程序如下:DATASEGMENTBNUMDB270FHDNUMDB4 DUP(?) ;存放BCD碼的緩沖區(qū)DATAENDSCODESEGMENTASSUME CS:CODE,DS:DATABINBCDPROCFARBEGIN: MOVAX,DATAMOVDS,AXMOVAX,BNUM ;取二進制數(shù)LEABX,DNUM ;BCD碼緩沖區(qū)首地址送BX16 ;

10、計算百位的個數(shù) MOV DL,0 ;千位的個數(shù)計數(shù)器AGAIN1: SUB AX,1000 ;(AX)-1000 JC NEXT1 ;若0,則退出循環(huán) INC DL ;(DL)+1 JMP AGAIN1NEXT1: ADD AX,1000 ;(AX)(AX)+1000 MOV BX,DL ;存千位的個數(shù) ;計算百位的個數(shù) MOV DL,0 ;百位的個數(shù)計數(shù)器AGAIN2: SUB AX,100 ;(AX)-100 JC NEXT2 INC DL JMP AGAIN2NEXT2: ADD AX,100 MOV BX+1,DL ;存百位的個數(shù)17 MOV DL,0 ;十位的個數(shù)計數(shù)器AGAIN3:

11、 SUB AX,10 ;(AX)-10 JC NEXT3 INC DL JMP AGAIN3NEXT3: ADD AX,10 MOV BX+2,DL ;存十位的個數(shù) MOV BX+3,AL ;存?zhèn)€位的個數(shù) MOV AH,4CH INT 21HBINBCD ENDP;CODE ENDS END BEGIN18BCDASCII 前面舉例介紹過,略。二進制串轉換為ASCII碼 一個二進制位串若要送顯示或打印, 需把串中每一位(0或1)化為ASCII碼。 思路:先將目標串全部預置為30H,再把每個二進制位逐位左移至CF,然后判CF=0?若是,取下一位;若不是,將31H送此單元。 流程圖如下:19初始化

12、用0填滿串取要轉換的數(shù)左移1位存入1結束CF=1?轉換完?調整指針NN20匯編程序如下:DATASEGMENTNUMDW6F78HSTRINGDB16 DUP(?)DATAENDS;CODESEGMENTASSUME CS:CODE,DS:DATABINCAPROCFARBEGIN:MOVAX,DATAMOVDS,AXMOVES,AXCLDLEADI,STRINGMOVCX,16 ;串的長度21MOVAL,30HREPSTOSB ;串中全部填充為0MOVCX,16LEADI,STRINGMOVAL,1MOVBX,NUM ;(BX)=6F78HAGAIN:RCLBX,1 ;含進位位循環(huán)左移JNC

13、NEXT ;若為0,轉 MOV DI,AL ;若為1,對應位送入1NEXT:INCDILOOPAGAIN22MOVAH,4CHINT21HBINCAENDPCODEENDSENDBEGIN 232.子程序的參數(shù)傳遞 編寫子程序時,很重要的一個工作是如何把參數(shù)傳給子程序,這個過程叫參數(shù)傳送。 傳送方法有:把參數(shù)放在CPU內(nèi)部寄存器中把參數(shù)放在變量中把參數(shù)放在地址表中利用堆棧傳送參數(shù)24 下面舉例介紹第4種方法,它通常在主程序中把參數(shù)或參數(shù)地址保存在堆棧中,而在子程序中將參數(shù)從堆棧取出來。例:把一個用十六進制表示的字ASCII碼,然 后送到屏幕上顯示。 匯編程序如下:DATASEGMENTNUMD

14、W25AFH ;要顯示的數(shù)STRINGDB4 DUP(?),13,10,$DATAENDS25STACKSEGMENTDB 100 DUP(?)TOP EQU $ STACKENDS ; CODESEGMENTASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACKBEGIN:MOVAX,DATAMOVDS,AXMOVES,AXMOVAX,STACKMOVSS,AX MOV SP,TOP LEABX,STRING;取變量偏址PUSHBX;將偏址壓棧PUSHNUM;將變量壓棧00020064H0062H(SP)25AF0060H堆棧26 CALLBINHEX;(SP)=00

15、5EH CS:0113 LEADX,STRING;(DX)=0002HMOVAH,9INT21HMOVAH,4CHINT21H;*BINHEXPROCPUSHBP;(SP)=005CHMOVBP,SP;(BP)=005CHPUSHAX ;(SP)=005AHPUSHDI ;(SP)=0058HPUSHCX ;(SP)=0056HPUSHDX ;(SP)=0054H00020064H0062H25AF0060H005EH0113005CH(SP)返回地址(IP)原(BP)2700020064H0062H25AF0060H005EH0113xxxx005CH(BP) PUSHF ;(SP)=005

16、2H MOV AX,BP+4 ;(AX)=25AFH MOV DI,BP+6 ;(DI)=0002H ADD DI,LENGTH STRING-4;(DI)=0005H MOV DX,AX ;(DX)=25AFH MOV CX,4 STD ;從后往前存AGAIN:AND AX,0FH ;第一次(AX)=000FH CALL HEXD ;轉換為ASCII碼 STOSB PUSH CX MOV CL,4 SHR DX,CL ;邏輯右移4位 MOV AX,DX ;第1次(AX)=025AH POP CX LOOP AGAIN ;(CX)-1=0?不等,轉+428POPFPOPDX POPCXPOPDIPOPAXPOPBPRET4 BINHEX ENDP ;*HEXD PROC CMP AL,0AH JL LP ADD AL,7LP: ADD AL,30H RETHEXD ENDPCODE ENDS END BEGIN0064H00

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論