微機原理與接口技術(第四版)課后習題答案-(1)._第1頁
微機原理與接口技術(第四版)課后習題答案-(1)._第2頁
微機原理與接口技術(第四版)課后習題答案-(1)._第3頁
微機原理與接口技術(第四版)課后習題答案-(1)._第4頁
已閱讀5頁,還剩46頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、第 1 章 微型計算機系統(tǒng)習題 1.1簡答題(2)總線信號分成哪三組信號?(3)PC 機主存采用 DRAM 組成還是 SRAM 組成?(5)ROM-BIOS 是什么?(6)中斷是什么?(9)處理器的“取指譯碼執(zhí)行周期”是指什么?解答 總線信號分成三組,分別是數據總線、地址總線和控制總線。 PC 機主存采用 DRAM 組成。 ROM-BIOS 是“基本輸入輸出系統(tǒng)”,操作系統(tǒng)通過對BIOS 的調用驅動各硬件設備,用戶也可以在應用程序中調用BIOS 中的許多功能。 中斷是 CPU 正常執(zhí)行程序的流程被某種原因打斷、并暫時停止,轉向執(zhí)行事先安排好的一段處理程序, 待該處理程序結束后仍返回被中斷的指令

2、繼續(xù)執(zhí)行的過程。 指令的處理過程。處理器的“取指譯碼執(zhí)行周期”是指處理器從主存儲器讀取指令(簡稱取指),翻譯指令代碼的功能(簡稱譯碼),然后執(zhí)行指令所規(guī)定的操作(簡稱執(zhí)行)的過程。習題 1.3填空題(2)Intel 8086 支持 _容量主存空間, 80486 支持 _容量主存空間。(3)二進制 16 位共有 _個編碼組合,如果一位對應處理器一個地址信號, 16 位地址信號共能尋址 _容量主存空間。(9)最初由公司采用 Intel 8088 處理器和()操作系統(tǒng)推出PC 機。 1MB , 4GB 216,64KB(9)IBM,DOS習題 1.4說明微型計算機系統(tǒng)的硬件組成及各部分作用。解答CP

3、U:CPU 也稱處理器,是微機的核心。它采用大規(guī)模集成電路芯片,芯片內集成了控制器、 運算器和若干高速存儲單元 (即寄存器)。處理器及其支持電路構成了微機系統(tǒng)的控制中心,對系統(tǒng)的各個部件進行統(tǒng)一的協(xié)調和控制。存儲器:存儲器是存放程序和數據的部件。外部設備:外部設備是指可與微機進行交互的輸入(Input)設備和輸出( Output)設備,也稱 I/O 設備。 I/O 設備通過 I/O 接口與主機連接??偩€:互連各個部件的共用通道,主要含數據總線、地址總線和控制總線信號。習題 1.7區(qū)別如下概念:助記符、匯編語言、匯編語言程序和匯編程序。解答助記符:人們采用便于記憶、 并能描述指令功能的符號來表示

4、機器指令操作碼,該符號稱為指令助記符。匯編語言:用助記符表示的指令以及使用它們編寫程序的規(guī)則就形成匯編語言。匯編語言程序: 用匯編語言書寫的程序就是匯編語言程序, 或稱匯編語言源程序。匯編程序:匯編語言源程序要翻譯成機器語言程序才可以由處理器執(zhí)行。 這個翻譯的過程稱為“匯編”,完成匯編工作的程序就是匯編程序( Assembler)。第 2 章 處理器結構習題 2.1簡答題(1)ALU 是什么?(2)8086 的取指為什么可以被稱為指令預取?(4)堆棧的存取原則是什么?(5)標志寄存器主要保存哪方面的信息?(6)執(zhí)行了一條加法指令后,發(fā)現ZF1,說明結果是什么?(9)匯編語言源程序文件中,END

5、 語句后的語句會被匯編嗎?解答 ALU 是算術邏輯運算單元,負責處理器所能進行的各種運算,主要是算術運算和邏輯運算。 取指是指從主存取出指令代碼通過總線傳輸到處理器內部指令寄存器的過程。 8086 分成總線接口單元和指令執(zhí)行單元,可以獨立操作。在執(zhí)行單元執(zhí)行一條指令的同時, 總線接口單元可以讀取下一條指令, 等到執(zhí)行時不需要進行取指了,所以稱為預取。 堆棧的存取原則是先進后出(也稱為后進先出)操作方式存取數據。 標志寄存器主要保存反映指令執(zhí)行結果和控制指令執(zhí)行形式的有關狀態(tài)。 執(zhí)行了一條加法指令后,發(fā)現ZF 1,表明運算結果為0。 不會。習題 2.3填空題(3)邏輯地址由 _和_兩部分組成。代

6、碼段中下一條要執(zhí)行的指令由CS 和 _寄存器指示,后者在實地址模型中起作用的僅有_寄存器部分。(4)進行 8 位二進制數加法: 1011101001101100,8 位結果是 _,標志 PF_。(5)在實地址工作方式下,邏輯地址“7380H 400H”表示的物理地址是_,并且該段起始于 _物理地址。(9)除外設數據外的數據尋址方式有 3 類,分別被稱為_和_。_、解答 段地址,偏移地址, 00100110,0EIP, IP 73C00H,73800H 立即數尋址、寄存器尋址和存儲器尋址習題 2.4 處理器內部具有哪 3 個基本部分? 8086 分為哪兩大功能部件?其各自的主要功能是什么?解答處

7、理器內部有 ALU 、寄存器和指令處理三個基本單元。8086 有兩大功能部件:總線接口單元和執(zhí)行單元。總線接口單元:管理著 8086 與系統(tǒng)總線的接口,負責處理器對存儲器和外設進行訪問。 8086 所有對外操作必須通過 BIU 和這些總線進行。執(zhí)行單元 EU:負責指令譯碼、數據運算和指令執(zhí)行。習題 2.5 8086 怎樣實現了最簡單的指令流水線?解答8086 中,指令的讀取是在 BIU 單元,而指令的執(zhí)行是在 EU 單元。因為 BIU 和 EU 兩個單元相互獨立、分別完成各自操作,所以可以并行操作。也就是說,在 EU 單元對一個指令進行譯碼執(zhí)行時, BIU 單元可以同時對后續(xù)指令進行讀?。贿@就

8、是最簡單的指令流水線技術。習題 2.8 什么是 8086 中的邏輯地址和物理地址?邏輯地址如何轉換成物理地址?請將如下邏輯地址用物理地址表達(均為十六進制形式): FFFF0 40 17 2000 4500 B8214567 解答物理地址:在處理器地址總線上輸出的地址稱為物理地址。 每個存儲單元有一個唯一的物理地址。邏輯地址:在處理器內部、程序員編程時采用邏輯地址,采用“段地址:偏移地址“形式。某個存儲單元可以有多個邏輯地址,即處于不同起點的邏輯段中,但其物理地址是唯一的。邏輯地址轉換成物理地址:邏輯地址由處理器在輸出之前轉換為物理地址。將邏輯地址中的段地址左移二進制 4 位(對應 16 進制

9、是一位,即乘以 16),加上偏移地址就得到 20 位物理地址。 FFFFH:0 FFFF0H 40H:17H 00417H 2000H:4500H24500H B821H:4567H BC777H習題 2.12 匯編語句有哪兩種,每個語句由哪4 個部分組成?解答匯編語句有兩種:執(zhí)行性語句(處理器指令)、說明性語句(偽指令)。每個語句有:標號、指令助記符、操作數或參數、注釋4 個部分組成。習題2.16 說明下列指令中源操作數的尋址方式?假設VARD是一個雙字變量。(1)mov edx,1234h(2)mov edx,vard(3)mov edx,ebx(4)mov edx,ebx(5)mov e

10、dx,ebx+1234h(6)mov edx,vardebx(7)mov edx,ebx+edi(8)mov edx,ebx+edi+1234h(9)mov edx,vardesi+edi(10) mov edx,ebp*4解答 立即數 直接 寄存器 寄存器間接 寄存器相對 寄存器相對 基址變址 相對基址變址 相對基址變址 帶比例尋址第 3章數據處理習題 3.1簡答題(1)使用二進制 8 位表達無符號整數, 257 有對應的編碼嗎?(2)字符“ F”和數值 46H 作為 MOV 指令的源操作數有區(qū)別嗎?(3)為什么可以把指令“ MOV AX, (3467H)*3 ”中的數值表達式看成是常量?(

11、4)數值 500,能夠作為字節(jié)變量的初值嗎?(6)都是獲取偏移地址, 為什么指令“LEA EBX, ESI ”正確,而指令“ MOV EBX, OFFSETESI ”就錯誤?(7)INC,DEC,NEG 和 NOT 都是單操作數指令,這個操作數應該是源操作數還是目的操作數?(9)乘除法運算針對無符號數和有符號數,有兩種不同的指令。只有一種指令的加減法如何區(qū)別無符號數和有符號數運算?(10)邏輯與運算為什么也稱為邏輯乘?解答 沒有。使用二進制8 位表達無符號整數, 257 沒有對應的編碼。 字符“ F”的 ASCII 碼就是數值 46H,所以沒有區(qū)別。 匯編程序在匯編過程中對數值表達式計算,得到

12、一個確定的數值,故稱數值表達式為常量。 不能。數值 500 大于一個字節(jié)所能表達的數據量,所以不能為字節(jié)變量賦值。 前者在指令執(zhí)行時獲得偏移地址,是正確的;但后者的 OFFSET 只能在匯編階段獲得偏移地址, 但此時寄存器內容是不可知的, 所以無法獲得偏移地址。 INC ,DEC,NEG 和 NOT 指令的操作數既是源操作數也是目的操作數。 加減法不區(qū)別無符號數和有符號數,但根據運算結果分別設置標志寄存器的 CF 和 OF 標志,可利用 CF 和 OF 進行區(qū)別。 邏輯與運算規(guī)則類似二進制的乘法,所以稱其為邏輯乘。習題 3.3填空題(1)定義字節(jié)變量的偽指令助記符是_,獲取變量名所具有的偏移地

13、址的操作符是 _。(2)計算機中有一個“ 01100001”編碼。如果把它認為是無符號數,它是 10 進制數 _;如果認為它是 BCD 碼,則表示真值 _;又如果它是某個ASCII 碼,則代表字符 _。(3)C 語言用“ n”表示讓光標回到下一行首位,在匯編語言中需要輸出兩個控制字符:一個是回車,其 ASCII 碼是 _,它將光標移動到當前所在行的首位;另一個是換行,其ASCII 碼是 _,它將光標移到下一行。(4)數據段有語句 “ H8843 DWORD 99008843H”,代碼段指令 “ MOV CX, WORD PTR H8843 ”執(zhí)行后, CX _。(5)用 DWORD 定義的一個

14、變量 XYZ ,它的類型是 _,用“TYPEXYZ ”會得到數值為_。如果將其以字量使用,應該用_說明。(6)數據段有語句“ ABC BYTE 1,2,3 ”,代碼段指令“ MOV CL, ABC+2 ” 執(zhí)行后, CL _。解答 BYTE ,OFFSET 97,61,小寫字母 a 0DH(13), 0AH (10) 8843H DWORD ,4,WORD PTR XYZ 3習題 3.4下列十六進制數表示無符號整數,請轉換為十進制形式的真值:FFH 0H 5EH EFH 解答 255 0 94 239習題 3.5將下列十進制數真值轉換為壓縮BCD 碼:12246899解答 12H 24H 68

15、H 99H習題 3.6將下列壓縮 BCD 碼轉換為十進制數: 10010001 10001001 00110110 10010000 解答 91 89 36 90習題 3.7將下列十進制數用8 位二進制補碼表示: 0 127 127 57解答 00000000 01111111 10000001 11000111習題 3.8進行十六進制數據的加減運算,并說明是否有進位或借位: 1234H7802H F034H 5AB0H C051H 1234H 9876HABCDH解答 1234H7802H8A36H ,無進位 F034H 5AB0H 4AF4H ,有進位 C051H 1234H BE1DH

16、,無借位 9876HABCDH ECA9H ,有借位習題 3.10 設置一個數據段,按照如下要求定義變量或符號常量: my1b 為字符串變量: Personal Computer my2b 為用十進制數表示的字節(jié)變量: 20 my3b 為用十六進制數表示的字節(jié)變量: 20 my4b 為用二進制數表示的字節(jié)變量: 20 my5w 為 20 個未賦值的字變量 my6c 為 100 的常量 my7c 表示字符串: Personal Computer解答my1b my2b my3b my4b my5w my6c my7cbyte Personal Computerbyte 20byte 14hbyte

17、 00010100bword 20 dup(?)= 100equ 習題 3.11 定義常量 NUM ,其值為 5;數據段中定義字數組變量 DATALIST ,它的頭 5 個字單元中依次存放 -10 , 2, 5 和 4,最后 1 個單元初值不定。解答numequ 5datalistbyte -10,2,5,4,?習題 3.12 從低地址開始以字節(jié)為單位,用十六進制形式給出下列語句依次分配的數值:byte ABC,10,10h,EF,3 dup(-1,?,3 dup(4)word 10h,-5,3 dup(?)解答41 42 43 0A 10 45 46 FF 00 04 04 04 FF 00

18、 04 04 04 FF 00 04 04 0410 00 FB FF 00 00 00 00 00 00習題 3.19 請分別用一條匯編語言指令完成如下功能:(去 E)(1)把 EBX 寄存器和 EDX 寄存器的內容相加,結果存入 EDX 寄存器。(2)用寄存器 EBX 和 ESI 的基址變址尋址方式把存儲器的一個字節(jié)與 AL寄存器的內容相加,并把結果送到AL 中。(3)用 EBX 和位移量 0B2H 的寄存器相對尋址方式把存儲器中的一個雙字和 ECX 寄存器的內容相加,并把結果送回存儲器中。(4)將 32 位變量 VARD 與數 3412H 相加,并把結果送回該存儲單元中。(5)把數 0A

19、0H 與 EAX 寄存器的內容相加,并把結果送回EAX 中。解答 add edx,ebx add al,ebx+esi add bx+0b2h,cx add varw,3412h add eax,0a0h習題 3.20 分別執(zhí)行如下程序片斷,說明每條指令的執(zhí)行結果:(去 E)(1)mov eax,80h; EAX _add eax,3; EAX _,CF _,SF_add eax,80h; EAX _,CF _,OF_adc eax,3; EAX _,CF _,ZF_(2)mov eax,100; EAX _add ax,200; EAX _, CF_(3)mov eax,100add al,

20、200; EAX _; EAX _, CF_(4)mov al,7fhsub al,8sub al,80hsbb al,3; AL _; AL_,CF_,SF_; AL_,CF_,OF_; AL_,CF_,ZF_解答(1); EAX 80H; EAX 83H,CF0,SF0; EAX 103H, CF0,OF 0; EAX 106H, CF0,ZF 0(2); EAX 100; EAX 300,CF0(3); EAX 100; EAX 44,CF1(包含 256 的進位含義: 25644 300)(4)mov al,7fhsub al,8sub al,80hsbb al,3; AL; AL;

21、AL; AL7FH77H, CF0,SF 0F7H, CF1,OF 1F3H, CF0,ZF 0習題3.21 (推敲)給出下列各條指令執(zhí)行后AL 值,以及 CF、ZF、 SF、 OF 和 PF 的狀態(tài):mov al,89hadd al,aladd al,9dhcmp al,0bchsub al,aldec alinc al解答mov al,89hadd al,al; AL; AL89H12HCF ZF SF OF PF10011add al,9dh; AL 0AFH 00101cmp al,0bch; AL 0AFH10101sub al,al; AL 00H01001dec al; AL 0

22、FFH00101inc al; AL 00H01001習題 3.22 有兩個 64 位無符號整數存放在變量 buffer1 和 buffer2 中,定義數據、編寫代碼完成 EDX.EAX buffer1 buffer2 功能。 (去 E)解答; 數據段buffer1 qword 67883000hbuffer2 qword 67762000h; 代碼段mov eax,dword ptr buffer1mov edx,dword ptr buffer1+4sub eax,dword ptr buffer2sbb edx,dword ptr buffer2+4習題 3.23 分別執(zhí)行如下程序片斷,

23、說明每條指令的執(zhí)行結果:(去 E)(1)mov esi,10011100b; ESI _Hand esi,80h; ESI _Hor esi,7fh; ESI _Hxor esi,0feh; ESI_H(2)mov eax,1010b ; EAX_Bshr eax,2; EAX _B,CF_shl eax,1; EAX _B,CF_and eax,3; EAX _B,CF_(3)mov eax,1011b ; EAX_Brol eax,2; EAX _B,CF_rcr eax,1; EAX _B,CF_or eax,3; EAX _B,CF_(4)xor eax,eax; EAX _,CF _

24、,OF_; ZF _,SF_,PF_解答(1); ESI 9CH; ESI 80H; ESI FFH; ESI 01H(2); EAX 1010B(可以有前導 0,下同); EAX 0010B,CF 1; EAX 0100B,CF 0; EAX 0000B,CF 0(3); EAX 1011B(可以有前導 0,下同); EAX 101100B,CF0; EAX 10110B,CF0; EAX 10111B,CF0(4); EAX 0, CF0,OF 0; ZF 1, SF0,PF 1習題 3.24 3.24 給出下列各條指令執(zhí)行后AX 的結果,以及狀態(tài)標志CF、OF、SF、ZF、PF 的狀態(tài)。

25、mov ax,1470hand ax,axor ax,axxor ax,axnot axtest ax,0f0f0h解答mov ax,1470h; AX 1470H CF OFSF ZF PFand ax,ax; AX 1470H 00000or ax,ax; AX 1470H 00000xor ax,ax; AX 0000H 00011not ax; AX FFFFH 00011test ax,0f0f0h; AX0F0F0H00101習題 3.25 邏輯運算指令怎么實現復位、置位和求反功能?解答AND 指令同“ 0”與實現復位, OR 指令同“ 1”或實現置位, XOR 同“ 1” 異或實

26、現求反。習題 3.27 (去 E)編程將一個 64 位數據邏輯左移 3 位,假設這個數據已經保存在 EDX.EAX 寄存器對中。解答; 代碼段mov ecx,3again: shl eax,1rcl edx,1loop again習題 3.28 編程將一個壓縮 BCD 碼變量(例如 92H )轉換為對應的 ASCII 碼,然后調用 DISPC 子程序(在輸入輸出子程序庫中)顯示。解答; 數據段bcdbyte 92h; 代碼段mov al,bcdshr al,4add al,30hcall dispcmov al,bcdand al,0fhadd al,30hcall dispc習題 3.31

27、下面程序的功能是將數組 ARRAY1 的每個元素加固定值(8000H ),將和保存在數組 ARRAY2 。在空白處填入適當的語句或語句的一部分。; 數據段array1 dword 1,2,3,4,5,6,7,8,9,10array2 dword 10 dup(?); 代碼段mov ecx,lengthof array1mov ebx,0again: mov eax,array1ebx*4add eax,8000hmov _add ebx,_loop again解答mov array2ebx*4,eaxadd ebx,1第 4 章 匯編語言程序設計習題 4.1簡答題(3)為什么判斷無符號數大小和

28、有符號大小的條件轉移指令不同?(4)雙分支結構中兩個分支體之間的JMP 指令有什么作用?(5)為什么特別強調為子程序加上必要的注釋?(6)子程序采用堆棧傳遞參數,為什么要特別注意堆棧平衡問題?(7)參數傳遞的“傳值”和“傳址”有什么區(qū)別?(8)INCLUDE 語句和 INCLUDELIB 有什么區(qū)別?解答 無符號數和有符號數的操作影響兩組不同的標志狀態(tài)位,故判斷兩個無符號數和有符號數的大小關系要利用不同的標志位組合,所以有對應的兩組指令。 雙分支結構中兩個分支體之間的 JMP 指令,用于實現結束前一個分支回到共同的出口作用。 完整的子程序注釋可方便程序員調用該子程序,子程序注釋包括子程序名、子

29、程序功能、入口參數和出口參數、調用注意事項和其他說明等。 子程序保持堆棧平衡, 才能保證執(zhí)行 RET 指令時當前棧頂的內容是正確的返回地址。主程序也要保持堆棧平衡, 這樣才能釋放傳遞參數占用的堆??臻g,否則多次調用該子程序可能就致使堆棧溢出。 “傳值”是傳遞參數的一個拷貝,被調用程序改變這個參數不影響調用程序;“傳址”時,被調用程序可能修改通過地址引用的變量內容。 INCLUDE 語句包含的是文本文件、是源程序文件的一部分; INCLUDELIB 語句包含的是子程序庫文件。習題 4.3填空題(1)JMP 指令根據目標地址的轉移范圍和尋址方式,可以分成四種類型:段內轉移、 _,段內轉移、 _和段

30、間轉移、 _,段間轉移、 _。(2)假設在平展存儲模型下, EBX 1256H,雙字變量 TABLE 的偏移地址是 20A1H ,線性地址 32F7H 處存放 3280H,執(zhí)行指令“ JMP EBX ” 后 EIP_,執(zhí)行指令“ JMP TABLEEBX ”后 EIP_。(3)“ CMP EAX,3721H ”指令之后是JZ 指令,發(fā)生轉移的條件是EAX _ ,此時 ZF _ 。(去 E)( 5)循環(huán)結構程序一般有三個部分組成,它們是_,循環(huán)體和_部分。( 7 )過程定義開始是“ TEST PROC”語句,則過程定義結束的語句是_。宏定義開始是“ DISP MACRO ”語句,則宏定義結束的語

31、句是_。(8)利用堆棧傳遞子程序參數的方法是固定的,例如尋址堆棧段數據的寄存器是 _。(9)MASM 匯編語言中,聲明一個共用的變量應使用_偽指令;而使用外部變量要使用 _偽指令聲明。解答 相對尋址,間接尋址,直接尋址,間接尋址 1256H,3280H 3721H,1 循環(huán)初始,循環(huán)控制 TEST ENDP,ENDM EBP PUBLIC , EXTERN習題 4.6執(zhí)行如下程序片斷后, CMP 指令分別使得 5 個狀態(tài)標志 CF、ZF、SF、OF和 PF 為 0 還是為 1?它會使得哪些條件轉移指令指令 Jcc 的條件成立、發(fā)生轉移?mov eax,20hcmp eax,80h解答CF1ZF

32、0SF1OF0PF1可以使得條件成立、發(fā)生轉移的指令有:JCJSJPJNZJNO習題 4.8在采用奇偶校驗傳輸數據的接收端應該驗證數據傳輸的正確性。例如,如果采用偶校驗,那么在接收到的數據中,其包含“ 1”的個數應該為 0 或偶數個,否則說明出現傳輸錯誤。 現在,在接收端編寫一個這樣的程序,如果偶校驗不正確顯示錯誤信息, 傳輸正確則繼續(xù)。 假設傳送字節(jié)數據、 最高位作為校驗位,接收到的數據已經保存在 Rdata 變量中。解答; 數據段Rdatabyte 57h; 保存接收的數據errorbyte Error !,0; 代碼段mov al,Rdataand al,0ffh; 標志 PF反映“ 1

33、”的個數jp done; 個數為偶數,正確繼續(xù)mov eax,offset error; 個數為奇數,顯示出錯call dispmsgdone:習題 4.10 編程,首先測試雙字變量 DVAR 的最高位,如果為 1,則顯示字母“ L”;如果最高位不為 1,則繼續(xù)測試最低位,如果最低位為 1,則顯示字母“ R”;如果最低位也不為 1,則顯示字母“ M”。解答; 數據段dvardword 57h; 代碼段 mov eax,dvartest eax,80000000hjnz nextltest eax,1jnz nextrmov al,Mjmp donenextl: mov al,Ljmp done

34、nextr: mov al,Rdone:call dispc習題 4.11 編寫一個程序,先提示輸入數字“Input Number : 0 9”,然后在下一行顯示輸入的數字,結束;如果不是鍵入了 0 9 數字,就提示錯誤 “ Error! ”,繼續(xù)等待輸入數字。解答; 數據段inmsgbyte Input number(09): ,0ermsgbyte 0dh,0ah,Error! Input again: ,0; 代碼段mov eax,offset inmsg;提示輸入數字call dispmsgagain: call readc;等待按鍵cmp al,0;數字 9 ?ja erdispca

35、ll dispcrlfcall dispcjmp doneerdisp:mov eax,offset ermsgcall dispmsgjmp againdone:習題 4.12 有一個首地址為 ARRAY 的 20 個雙字的數組, 說明下列程序段的功能。mov ecx,20mov eax,0mov esi,eaxsumlp: add eax,arrayesiadd esi,4loop sumlpmov total,eax解答求這 20 個雙字的和,保存在TOTAL 變量,不關進心進位和溢出。習題 4.13 編程中經常要記錄某個字符出現的次數。現編程記錄某個字符串中空格出現的次數,結果保存在

36、SPACE 單元。解答; 數據段string byte Do you have fun with Assembly ?,0; 以 0 結尾的字符串spacedword ?; 代碼段mov esi,offset stringxor ebx,ebx;EBX 用于記錄空格數again: mov al,esicmp al,0jz donecmp al,20h; 空格的 ASCII 碼是 20Hjne next; 不相等、不是空格,轉移inc bx; 相等、是空格,空格個數加1next:inc esijmp again; 繼續(xù)循環(huán)done:mov space,ebx ;保存結果習題 4.14 編寫計算

37、100 個 16 位正整數之和的程序。如果和不超過16 位字的范圍( 65535 ),則保存其和到 WORDSUM ,如超過則顯示 Overflow ! 。解答;數據段arrayword 2005,2008,98 dup (1394);假設100 個16 位正整數wordsumword ?errorbyte Overflow !,0;代碼段and ebx,0mov ecx,100xor ax,axagain: add ax,arrayebx*2jc overinc ebxloop againmov wordsum,axover:mov eax,offset errorcall dispmsg習

38、題 4.15 在一個已知長度的字符串中查找是否包含“ BUG ”子字符串。如果存在,顯示“ Y”,否則顯示“ N”。解答; 數據段string byte If you find any error in the program, you can DEBUG it.count= sizeof stringbugbyte BUG;代碼段mov ecx,countmov edi,offset stringL1:mov esi,offset bugpush edimov edx,sizeof bugLN:mov al,esicmp edi,aljne L2inc esiinc edidec edxjn

39、e LNpop edimov al,Yjmp L3L2:pop ediinc ediloop L1mov al,NL3:call dispc習題 4.16 主存中有一個 8 位壓縮 BCD 碼數據,保存在一個雙字變量中。 現在需要進行顯示,但要求不顯示前導 0。由于位數較多,需要利用循環(huán)實現,但如何處理前導 0 和數據中間的 0 呢?不妨設置一個標記。編程實現。解答; 數據段bcddword 00371002h; 代碼段mov esi,bcdcmp esi,0jnz goonmov al,0call dispcjmp donegoon:mov ecx,8xor ebx,ebx; EBX 0,表

40、示可能是前導 0again: rol esi,4mov eax,esiand eax,0fh; EAX 低 4 位保存當前要顯示的 BCD碼cmp ebx,0; EBX 0,說明不是前導 0,要顯示jnz disp; EBX 0,說明可能是前導 0cmp eax,0jz next; EAX 0,說明是前導 0,不顯示mov ebx,1; EAX 0,沒有前導 0 了,令 EBX10disp:add al,30hcall dispcnext:loop againdone:習題 4.17 已知一個字符串的長度,剔除其中所有的空格字符。請從字符串最后一個字符開始逐個向前判斷、并進行處理。解答; 數據

41、段string byte Let us have a try !,0dh,0ah,0; 代碼段mov ecx,sizeof stringcmp ecx,2jb donelea eax,string;顯示處理前的字符串call dispmsgmov esi,ecxdec esioutlp: cmp stringesi, ;檢測是否是空格jnz next;不是空格繼續(xù)循環(huán)mov edi,esi;是空格,進入剔除空格分支dec ecxinlp:inc edimov al,stringedi;前移一個位置mov stringedi-1,alcmp edi,ecxjb inlpnext:dec esi;

42、繼續(xù)進行cmp esi,0jnz outlp;為0結束lea eax,string;顯示處理后的字符串done:call dispmsg習題 4.19 請按如下說明編寫子程序:子程序功能:把用 ASCII 碼表示的兩位十進制數轉換為壓縮 BCD 碼入口參數: DH 十位數的 ASCII 碼, DL 個位數的 ASCII 碼出口參數: AL 對應 BCD 碼解答asctob procshl dh,4mov al,dhand dl,0fhor al,dlretasctob endp習題 4.21 編寫一個源程序,在鍵盤上按一個鍵,將其返回的 ASCII 碼值顯示出來,如果按下 ESC 鍵(對應 ASCII 碼是 1BH )則程序退出。請調用書中的 HTOASC 子程序。解答; 代碼段,主程序again: call readc cmp al,1bh jz done mov bl,almov al,:call dispcmov al,blrol al,4call htoasc;調用子程

溫馨提示

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

評論

0/150

提交評論