微機原理與接口技術(樓順天版)課后習題解答.pdf_第1頁
微機原理與接口技術(樓順天版)課后習題解答.pdf_第2頁
微機原理與接口技術(樓順天版)課后習題解答.pdf_第3頁
微機原理與接口技術(樓順天版)課后習題解答.pdf_第4頁
微機原理與接口技術(樓順天版)課后習題解答.pdf_第5頁
已閱讀5頁,還剩112頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

微機原理與接口技術 樓順天 周佳社編著 科學出版社 找了好久 終于在期末從老師那兒弄了一份 希望對大家有用 微機原理與接口技術 樓順天 周佳社 編著 科學出版社 2006 年 習題解答 因時間緊 習題解答由部分老師提供 還沒有經(jīng)過仔細校對 肯定有 不少錯誤 請各位指正 另外 習題有多種解法 答案不唯一 僅供 參考 第 1 章 數(shù)制與碼制 1 將下列十進制數(shù)轉換成二進制數(shù) 1 58 2 67 625 3 5721 解 1 58D 0011 1010B 2 67 625D 0100 0011 1010B 3 5721D 0001 0110 0101 1001B 2 將二進制數(shù)變換成十六進制數(shù) 1 1001 0101B 2 11 0100 1011B 3 1111 1111 1111 1101B 4 0100 0000 10101B 5 0111 1111B 6 0100 0000 0001B 解 1 1001 0101B 95H 2 11 0100 1011B 34BH 3 1111 1111 1111 1101B FFFDH 4 0 1000 0001 0101B 815H 5 0111 1111B 7FH 6 0100 0000 0001B 401H 3 將十六進制數(shù)變換成二進制數(shù)和十進制數(shù) 1 78H 2 0A6H 3 1000H 4 0FFFFH 解 1 78H 120D 0111 1000B 2 0A6H 166D 1010 0110B 3 1000H 4096D 0001 0000 0000 0000H 4 0FFFFH 65535D 1111 1111 1111 1111B 4 將下列十進制數(shù)轉換成十六進制數(shù) 1 39 2 299 34375 3 54 5625 解 1 39D 27H 2 299 34375D 12B 58H 3 54 5625D 36 9H 5 將下列二進制數(shù)轉換成十進制數(shù) 1 10110 101B 2 10010010 001B 3 11010 1101B 解 1 10110 101B 22 625D 2 10010010 001B 146 125D 3 11010 1101B 26 8125D 6 計算 按原進制運算 1 10001101B 11010B 2 10111B 11100101B 3 1011110B 1110B 4 124AH 78FH 5 5673H 123H 6 1000H F5CH 解 1 10100111B 2 11111100B 3 1010000B 4 19D9H 5 5796H 6 A4H 7 已知 a 1011B b 11001B c 100110B 按二進制完成下列運算 并用十進制運算檢查 計算結果 1 a b 2 c a b 3 a b 4 c b 解 a 1011B 11D b 11001B 25D c 100110B 38D 1 100100B 36D 2 10B 2D 3 1 0001 0011B 275D 4 1B 余 1101B 13D 8 已知 a 00111000B b 11000111B 計算下列邏輯運算 1 a AND b 2 a OR b 3 a XOR b 4 NOT a 解 1 00000000B 2 11111111B 3 11111111B 4 11000111B 9 設機器字長為 8 位 寫出下列各數(shù)的原碼和補碼 1 1010101B 2 1010101B 3 1111111B 4 1111111B 5 1000000B 6 1000000B 解 1 原 01010101B 補 01010101B 2 原 11010101B 補 10101011B 3 原 01111111B 補 01111111B 4 原 11111111B 補 10000001B 5 原 01000000B 補 01000000B 6 原 11000000B 補 11000000B 10 寫出下列十進制數(shù)的二進制補碼表示 設機器字長為 8 位 1 15 2 1 3 117 4 0 4 15 5 127 6 128 7 80 解 1 00001111B 補 2 11111111B 補 3 01110101B 補 4 00000000B 補 5 11110001B 補 6 01111111B 補 7 10000000B 補 8 01010000B 補 11 設機器字長為 8 位 先將下列各數(shù)表示成二進制補碼 然后按補碼進行運算 并用十進 制數(shù)運算進行檢驗 1 87 73 2 87 73 3 87 73 4 87 73 5 87 73 6 87 73 解 1 1110B 14D 2 00001110B 進位舍棄 3 10100000B 96D 溢出 4 11110010B 14D 5 01100000B 96D 溢出 6 11110010B 14D 12 已知 a b c d 為二進制補碼 a 00110010B b 01001010B c 11101001B d 10111010B 計算 1 a b 2 a c 3 c b 4 c d 5 a b 6 c a 7 d c 8 a d c 解 1 01111100B 2 00011011B 3 00110011B 4 10100011B 5 11101000B 6 10110111B 7 11010001B 8 11B 13 設下列四組為 8 位二進制補碼表示的十六進制數(shù) 計算 a b 和 a b 并判斷其結果是否 溢出 1 a 37H b 57H 2 a 0B7H b 0D7H 3 a 0F7H b 0D7H 4 a 37H b 0C7H 解 1 a b 8EH 溢出 a b E0H 未溢出 2 8EH 未溢出 E0H 未溢出 3 CEH 未溢出 20H 未溢出 4 FEH 未溢出 70H 未溢出 14 求下列組合 BCD 數(shù)的二進制和十六進制表示形式 1 3251 2 12907 3 2006 解 1 0011 0010 0101 0001B 3251H 2 0001 0010 1001 0111B 12907H 3 0010 0000 0000 0110B 2006H 15 將下列算式中的十進制數(shù)表示成組合 BCD 碼進行運算 并用加 6 減 6 修正其結果 1 38 42 2 56 77 3 99 88 4 34 69 5 38 42 6 77 56 7 15 76 8 89 23 解 1 0011 1000B 0100 0010B 0111 1010B 低 BCD 碼位需要加 6 修正 0111 1010B 0000 0110B 1000 0000B 80BCD 2 0101 0110B 0111 0111B 1100 1101B 高 低 BCD 碼位都需要加 6 修正 1100 1101B 0110 0110B 0001 0011 0011B 133BCD 3 1001 1001B 1000 1000B 0001 0010 0001B 高 低 BCD 碼位都需要加 6 修正 0001 0010 0001B 0110 0110B 0001 1000 0111B 187BCD 4 0011 0100B 0110 1001B 1001 1101B 低 BCD 碼位需要加 6 修正 1001 1101B 0000 0110B 1010 0011B 修正結果使高 BCD 碼位需要加 6 修正 1010 0011B 0110 0000B 0001 0000 0011B 103BCD 5 00111000B 01000010B 1 1111 0110B 高 BCD 碼位需要減 6 修正 1 1111 0110B 0110 0000B 1 1001 0110B 100 96 4BCD 6 01110111B 01010110B 0010 0001B 21BCD 7 00011001B 01110110B 1 1001 1111B 高 低 BCD 碼位都需要減 6 修正 1 1001 1111B 01100110B 1 0011 1001B 100 39 61BCD 8 10001001B 00100011B 0110 0110B 66BCD 16 將下列字符串表示成相應的 ASCII 碼 用十六進制數(shù)表示 1 Example 1 2 XiDian University 3 108 652 4 How are you 5 Computer 6 Internet Web 解 1 45H 78H 61H 6DH 70H 6CH 65H 20H 31H 2 58H 69H 44H 69H 61H 6EH 20H 55H 6EH 69H 76H 65H 72H 73H 69H 74H 79H 3 2DH 31H 30H 38H 2EH 36H 35H 32H 4 48H 6FH 77H 20H 61H72H 65H 20H79H 6FH 75H 5 43H 6FH 6DH 70H 75H 74H 65H 72H 6 49H 6EH 74H 65H72H 6EH 65H 74H 20H 57H 65H 62H 17 將下列字符串表示成相應的 ASCII 碼 用十六進制數(shù)表示 1 Hello 2 123456 注 表示回車 3 ASCII 4 The number is 2315 解 1 48H 65H 6CH 6CH 6FH 2 31H 32H 33H 0DH 34H 35H 36H 3 41H 53H 43H 49H 49H 4 54H 68H 65H 20H 6EH 75H 6DH 62H 65H 72H 第 2 章 8086 CPU 結構與功能 1 微處理器內(nèi)部結構由哪幾部分組成 闡述各部分的主要功能 解 微處理器內(nèi)部結構由四部分組成 1 算術邏輯運算單元 ALU 完成所有的運算操作 2 工作寄存器 暫存尋址信息和計算過程中的中間結果 3 控制器 完成指令的讀入 寄存和譯碼 并產(chǎn)生控制信號序列使 ALU 完成指定操 作 4 I O 控制邏輯 處理 I O 操作 2 微處理器級總線有哪幾類 各類總線有什么作用 解 微處理器級總線有三類 1 數(shù)據(jù)總線 傳送信息 2 地址總線 傳送地址碼 3 控制總線 傳送控制信號 3 為什么地址總線是單向的 而數(shù)據(jù)總線是雙向的 解 地址碼只能由 CPU 生成 而數(shù)據(jù)需要在 CPU 和存儲器之間傳輸 4 8086 8088 微處理器內(nèi)部有哪些寄存器 其主要作用是什么 解 8086CPU 內(nèi)部有 14 個 16 位寄存器 其中 8 個通用寄存器 4 數(shù)據(jù)寄存器 AX BX CX DX 4 地址指針 變址寄存器 SI DI SP BP 4 個段寄存器 CS DS ES SS 2 個控制寄存器 指令指針 IP 微處理器狀態(tài)字 PSW 應該注意的是 可以在指令中用作為地址指針的寄存器有 SI DI BP 和 BX 在微處理 器狀態(tài)字 PSW 中 一共設定了 9 個標志位 其中 6 個標志位用于反映 ALU 前一次操 作的結果狀態(tài) CF PF AF ZF SF OF 另 3 個標志位用于控制 CPU 操作 DF IF TF 5 如果某微處理器有 20 條地址總線和 16 條數(shù)據(jù)總線 1 假定存儲器地址空間與 I O 地址空間是分開的 則存儲器地址空間有多大 2 數(shù)據(jù)總線上傳送的有符號整數(shù)的范圍有多大 解 1 存儲器地址空間為 20 21MB 2 有符號數(shù)范圍為 1515 2 21 即 32768 32767 6 將十六進制數(shù) 62A0H 與下列各數(shù)相加 求出其結果及標志位 CF AF SF ZF OF 和 PF 的值 1 1234H 2 4321H 3 CFA0H 4 9D60H 解 1 74D4H CF 0 AF 0 SF 0 ZF 0 OF 0 PF 1 2 A5C1H CF 0 AF 0 SF 1 ZF 0 OF 1 PF 0 3 3240H CF 1 AF 0 SF 0 ZF 0 OF 0 PF 0 4 0000H CF 1 AF 0 SF 0 ZF 1 OF 0 PF 1 7 從下列各數(shù)中減去 4AE0H 求出其結果及標志位 CF AF SF ZF OF 和 PF 的值 1 1234H 2 5D90H 3 9090H 4 EA04H 解 1 C754H CF 1 AF 0 SF 1 ZF 0 OF 0 PF 0 2 12B0H CF 0 AF 0 SF 0 ZF 0 OF 0 PF 0 3 45B0H CF 0 AF 0 SF 0 ZF 0 OF 1 PF 0 4 9F24H CF 0 AF 0 SF 1 ZF 0 OF 0 PF 1 9 寫出下列存儲器地址的段地址 偏移地址和物理地址 1 2134 10A0 2 1FA0 0A1F 3 267A B876 解 物理地址 段地址 10H 偏移地址 1 段地址 2134H 偏移地址 10A0H 物理地址 223E0H 2 段地址 1FA0H 偏移地址 0A1FH 物理地址 2041FH 3 段地址 267AH 偏移地址 B876H 物理地址 32016H 10 給定一個數(shù)據(jù)的有效地址為 2359H 并且 DS 490BH 求該數(shù)據(jù)的物理地址 解 物理地址 段地址 10H 偏移地址 物理地址 490BH 2359H 4B409H 11 如果在一個程序段開始執(zhí)行之前 CS 0A7F0H IP 2B40H 求該程序段的第 一個字的物理地址 解 物理地址 段地址 10H 偏移地址 物理地址 CS 10H IP AAA40H 12 IBM PC 有哪些寄存器可用來指示存儲器的地址 解 變址寄存器 SI DI 堆棧指針 SP BP 另外還有 BX 第 3 章 8086CPU 指令系統(tǒng) 1 寫出完成下列要求的變量定義語句 1 在變量 var1 中保存 6 個字變量 4512H 4512 1 100 3 10H 65530 2 在變量 var2 中保存字符串 BYTE word WORD 3 在緩沖區(qū) buf1 中留出 100 個字節(jié)的存儲空間 4 在緩沖區(qū) buf2 中 保存 5 個字節(jié)的 55H 再保存 10 個字節(jié)的 240 并將這一過程 重復 7 次 5 在變量 var3 中保存緩沖區(qū) buf1 的長度 6 在變量 pointer 中保存變量 var1 和緩沖區(qū) buf1 的偏移地址 解 var1 DW 4512H 4512 1 100 3 10H 65530 var2 DB BYTE word WORD buf1 DB 100 DUP buf2 DB 7 DUP 5 DUP 55H 10 DUP 240 var3 DB LENGTH buf1 pointer DW var1 buf1 或者 pointer DW OFFSET var1 OFFSET buf1 2 設變量 var1 的邏輯地址為 0100 0000 畫出下列語句定義的變量的存儲分配圖 var1 DB 12 12 20 6 4 DUP 0 55H var2 DB Assemble var3 DW AB cd E var4 DW var2 var5 DD var2 解 3 指令正誤判斷 對正確指令寫出源和目的操作數(shù)的尋址方式 對錯誤指令指出原因 設 VAR1 VAR2 為字變量 L1 為標號 1 MOV SI 100 2 MOV BX VAR1 SI 3 MOV AX BX 4 MOV AL DX 5 MOV BP AL 6 MOV VAR1 VAR2 7 MOV CS AX 8 MOV DS 0100H 9 MOV BX SI 1 10 MOV AX VAR1 VAR2 11 ADD AX LENGTH VAR1 12 OR BL TYPE VAR2 13 SUB DI 78H 14 MOVS VAR1 VAR2 15 PUSH 100H 16 POP CS 17 XCHG AX ES 18 MOV DS CS 19 JMP L1 5 20 DIV AX 10 21 SHL BL 2 22 MOV AL 15 23 23 MUL CX 24 XCHG CL SI 25 ADC CS 0100 AH 26 SBB VAR1 5 154 解 1 MOV SI 100 正確 源 立即數(shù)尋址 目的 寄存器尋址 2 MOV BX VAR1 SI 正確 源 寄存器相對尋址 目的 寄存器尋址 3 MOV AX BX 正確 源 寄存器間接尋址 目的 寄存器尋址 4 MOV AL DX 錯誤 寄存器間接尋址時 DX AX CX 不能作地址寄存器 5 MOV BP AL 錯誤 操作數(shù)類型不一致 6 MOV VAR1 VAR2 錯誤 兩存儲單元之間不能用 MOV 指令傳送數(shù)據(jù) 7 MOV CS AX 錯誤 CS 不能為目的操作數(shù) 8 MOV DS 0100H 錯誤 目的操作數(shù)為段寄存器時 源操作數(shù)不能為立即數(shù) 9 MOV BX SI 1 錯誤 指令類型不定 10 MOV AX VAR1 VAR2 錯誤 MOV 指令中不能完成加法運算 11 ADD AX LENGTH VAR1 正確 源 立即數(shù)尋址 目的 寄存器尋址 12 OR BL TYPE VAR2 正確 源 立即數(shù)尋址 目的 寄存器尋址 13 SUB DI 78H 錯誤 指令類型不定 14 MOVS VAR1 VAR2 正確 目的 源均為隱含尋址 操作數(shù)僅指出操作數(shù)類型 15 PUSH 100H 錯誤 將常數(shù)壓入堆棧 要通過寄存器來實現(xiàn) 16 POP CS 錯誤 目的操作數(shù)不能為 CS 17 XCHG AX ES 錯誤 XCHG 指令的操作數(shù)不能是段寄存器 18 MOV DS CS 錯誤 MOV 指令不能從段寄存器到段寄存器 19 JMP L1 5 正確 段內(nèi)直接轉移 20 DIV AX 10 錯誤 指令格式錯誤 21 SHL BL 2 錯誤 移位指令的移位數(shù)為 1 或者 CL 22 MOV AL 15 23 正確 源 立即數(shù)尋址 目的 寄存器 編譯時就處理為 38 23 MUL CX 正確 源 寄存器尋址 目的 寄存器尋址 24 XCHG CL SI 正確 源 寄存器間接尋址 目的 寄存器尋址 25 ADC CS 0100 AH 正確 源 寄存器尋址 目的 直接尋址 數(shù)據(jù)在代碼段中 26 SBB VAR1 5 154 正確 源 立即數(shù)尋址 目的 直接尋址 4 說明下列指令對的區(qū)別 1 MOV AX VAR1 與 MOV AX OFFSET VAR1 2 MOV AX VAR2 與 LEA AX VAR2 3 MOV AL LENGTH VAR1 與 MOV AL SIZE VAR1 4 MOV AL ES DI CMP AL SI 與 CMPSB 5 SHR AL 1 與 SAR AL 1 6 SHR AL 1 與 ROR AL 1 7 ROL BX 1 與 RCL BX 1 解 1 MOV AX VAR1 把變量 VAR1 對應地址單元中的一個字送入 AX MOV AX OFFSET VAR1 把 VAR1 的有效地址的偏移地址送入 AX 2 MOV AX VAR2 把變量 VAR2 對應地址單元中的一個字送入 AX LEA AX VAR2 把 VAR2 的有效地址的偏移地址送入 AX 3 MOV AL LENGTH VAR1 把變量 VAR1 的長度送入 AL MOV AL SIZE VAR1 把變量 VAR1 的大小送入 AL 4 MOV AL ES DI CMP AL SI 把以 ES 為段地址 DI 為偏移地址的一個字節(jié)送入 AL 并與以 SI 內(nèi)容為偏移地址的一個字節(jié)作比較 改變標志寄 存器內(nèi)容 相當于作 ES DI 與 DS SI 內(nèi)容比較 CMPSB 對字符串中的一字節(jié)比較 尋址方式隱含 源串的地址由 DS SI 指定 目的串的地址由 ES DI 指定 相當于作 DS SI 與 ES DI 內(nèi)容比較 5 SHR AL 1 AL 邏輯右移 1 位 最高位移入 0 最低位移入 CF SAR AL 1 AL 算術右移 1 位 以最高位內(nèi)容移入 最低位移入 CF 其余各位 右移一位 6 SHR AL 1 AL 邏輯右移 1 位 最高位移入 0 最低位移入 CF ROR AL 1 AL 的各位構成環(huán)形移位 右移一位 最低位內(nèi)容同時移入到 CF 和 最高位 7 ROL BX 1 BX 各位構成環(huán)形移位 左移一位 最高位內(nèi)容同時移入到 CF 和 最低位 RCL BX 1 BX 和 CF 構成環(huán)形移位 左移一位 CF 內(nèi)容移入到最低位 最 高位移入 CF 5 寫出下列轉移指令的尋址方式 設 L1 為標號 VAR1 為字型變量 DVAR1 為雙字型變量 1 JMP L1 2 JMP NEAR L1 3 JNZ L1 4 JMP BX 5 JG L1 6 JMP VAR1 SI 7 JMP FAR PTR L1 8 JMP DVAR1 解 1 JMP L1 段內(nèi)直接尋址 2 JMP NEAR PTR L1 段內(nèi)直接尋址 3 JNZ L1 段內(nèi)直接尋址 4 JMP BX 段內(nèi)間接尋址 5 JG L1 段內(nèi)直接尋址 6 JMP VAR1 SI 段內(nèi)間接尋址 7 JMP FAR PTR L1 段間直接尋址 8 JMP DVAR1 段間間接尋址 6 設 DS 2000H BX 0100H SI 0002H 20100 3412H 20102 7856H 21200 4C2AH 21202 65B7H 求下列指令執(zhí)行后 AX 寄存器的內(nèi)容 1 MOV AX 1200H 2 MOV AX BX 3 MOV AX 1200H 4 MOV AX BX 5 MOV AX 1100 BX 6 MOV AX BX SI 7 MOV AX 1100 BX SI 解 1 1200H 2 0100H 3 4C2AH 4 3412H 5 4C2AH 6 7856H 7 65B7H 7 執(zhí)行下列指令后 DX 寄存器中的內(nèi)容是多少 TABLE DW 25 36 1 16 10000 13 PYL DW 7 MOV BX OFFSET TABLE ADD BX PYL MOV DX BX 解 DX 10FFH 由 16 FFF0H 的高 8 位和 10000 2710H 的低 8 位構成 8 如果堆棧的起始地址為 2200 0000 棧底為 0100H SP 00A8H 求 1 棧頂?shù)刂?2 SS 的內(nèi)容 3 再存入數(shù)據(jù) 5678H 3AF2H 后 SP 的內(nèi)容 解 棧頂?shù)刂?00A8H SS 2200H 再存入 2 個字后 SP 00A4H 9 設已用偽指令 EQU 定義了 4 個標識符 N1 EQU 2100 N2 EQU 10 N3 EQU 20000 N4 EQU 25000 下列指令是否正確 并說明原因 1 ADD AL N1 N2 2 MOV AX N3 N4 3 SUB BX N4 N3 4 SUB AH N4 N3 N1 5 ADD AL N2 6 MOV AH N2 N2 解 1 錯誤 N1 N2 2090 255 2 正確 3 正確 4 錯誤 N4 N3 N1 2900 255 5 正確 6 正確 10 按下列要求寫出指令 1 將 AX 寄存器的低 4 位清零 其余位不變 2 將 BX 寄存器的低 4 位置 1 其余位不變 3 將 AL 寄存器的低 4 位保持不變 高 4 位取反 4 測試 BX 中的位 1 和位 2 當這兩位同時為 0 時將 AL 置 0FFH 否則 AL 清零 5 測試 BX 中的位 1 和位 2 當這兩位有一位為 0 時將 AL 置 0FFH 否則 AL 清零 6 將 AL 中保存的字母 ASCII 碼變換成相應的大寫字母的 ASCII 碼 7 將 AL 中保存的字母 ASCII 碼變換成相應的小寫字母的 ASCII 碼 8 將 AX 中的各位取反 9 將 DX 中的低 7 位取反 高 9 位不變 10 將 CX 中的低 8 位與高 8 位互換 解 1 AND AX 0FFF0H 2 OR BX 000FH 3 XOR AL 0F0H 4 TEST BX 06H 5 MOV AX BX JZ ZERO AND AX 06H MOV AL 00H XOR AX 06H JMP OVER JZ OVER ZERO MOV AL 0FFH MOV AL 0FFH OVER OVER 6 AND AL 5FH 或者 CMP AL 61H JL OVER 無需變換或不是字母 CMP AL 7AH JG OVER 不是字母 AND AL 5FH 或 SUB AL 20H OVER 7 OR AL 20H 或者 CMP AL 41H JL OVER 不是字母 CMP AL 5AH JG OVER 無需變換或不是字母 OR AL 20H 或 ADD AL 20H OVER 8 XOR AX 0FFFFH 或者 NOT AX 9 XOR DX 007FH 10 XCHG CH CL 11 寫出完成下述功能的程序段 1 傳送 40H 到 AL 寄存器 2 將 AL 的內(nèi)容乘以 2 3 傳送 16H 到 AH 寄存器 4 AL 的內(nèi)容加上 AH 的內(nèi)容 計算最后結果 AL 解 1 MOV AL 40H 2 SHL AL 1 3 MOV AH 16H 4 ADD AL AH AL 96H 12 寫出完成下述功能的程序段 1 從緩沖區(qū) BUF 的 0004 偏移地址處傳送一個字到 AX 寄存器 2 將 AX 寄存器的內(nèi)容右移 2 位 3 將 AX 內(nèi)容與 BUF 的 0006 偏移地址處的一個字相乘 4 相乘結果存入 BUF 的 0020H 偏移地址處 低位在前 解 1 LEA SI BUF MOV AX SI 4 2 SHR AX 1 SHR AX 1 3 MUL WORD PTR 6 SI 4 MOV 20H SI AX MOV 22H SI DX 13 設 BX 11001011B 變量 VAR 的內(nèi)容為 00110010B 求下列指令單獨執(zhí)行后 BX 的內(nèi) 容 1 XOR BX VAR 2 AND BX VAR 3 OR BX VAR 4 XOR BX 11110000B 5 AND BX 00001111B 6 TEST BX 1 解 1 00F9H 2 0002H 3 00FBH 4 003BH 5 000BH 6 00CBH 14 設 DX 10111011B CL 3 CF 1 求下列指令單獨執(zhí)行后 DX 的內(nèi)容 1 SHR DX 1 2 SAR DX CL 3 SHL DX CL 4 SHL DX 1 5 ROR DX CL 6 ROL DL CL 7 SAL DH 1 8 RCL DX CL 9 RCR DL 1 解 DX 0000 0000 1011 1011B CF 1 CL 3 1 SHR DX 1 DX 邏輯右移 1 0000 0000 0101 1101B 005DH 2 SAR DX CL DX 算術右移 3 0000 0000 0001 0111B 0017H 3 SHL DX CL DX 邏輯左移 3 0000 0101 1101 1000B 05D8H 4 SHL DX 1 DX 邏輯左移 1 0000 0001 0111 0110B 0176H 5 ROR DX CL DX 循環(huán)右移 3 0110 0000 0001 0111B 6017H 6 ROL DL CL DL 循環(huán)左移 3 0000 0000 1101 1101B 00DDH 7 SAL DH 1 DH 算術左移 1 0000 0000 1011 1011B 00BBH 8 RCL DX CL DX 帶進位循環(huán)左移 3 0000 0101 1101 1100B 05DCH 9 RCR DL 1 DL 帶進位循環(huán)右移 1 0000 0000 1101 1101B 00DDH 15 選擇題 各小題只有一個正確答案 1 執(zhí)行下列三條指令后 MOV SP 1000H PUSH AX CALL BX a SP 1000H b SP 0FFEH c SP 1004H d SP 0FFCH 2 要檢查寄存器 AL 中的內(nèi)容是否與 AH 相同 應使用的指令為 a AND AL AH b OR AL AH c XOR AL AH d SBB AL AH 3 指令 JMP NEAR PTR L1 與 CALL L1 L1 為標號 的區(qū)別在于 a 尋址方式不同 b 是否保存 IP 的內(nèi)容 c 目的地址不同 d 對標志位的影響不同 解 1 D PUSHU AX 則 AX 入棧 SP 0FFEH CALL BX 則 IP 入棧 SP 0FFCH 2 C 異或 若相同 則 AL 0 ZF 1 3 B 16 寄存器 DX AX 組成 32 位數(shù) DX 為高位 編寫程序段實現(xiàn) 1 DX AX 右移 3 位 并將移出的低 3 位保存在 CL 中 2 DX AX 左移 3 位 并將移出的高 3 位保存在 CL 中 解 1 移出的 3 位應該按時序移入 CL 中 XOR CL CL MOV BL 3 L1 SHR DX 1 RCR AX 1 RCL CL 1 DEC BL JNZ L1 2 移出的 3 位應該按時序移入 CL 中 XOR CL CL MOV BL 3 L1 SHL AX 1 RCR DX 1 RCR CL 1 DEC BL JNZ L1 17 編寫程序段實現(xiàn)將 BL 中的每一位重復 4 次 構成 32 位的雙字 DX AX 例如當 BL 01011101B 時 則得到的 DX 0F0FH AX 0FF0FH 解 算術右移時 移入的值就是最高位本身 這樣可以使位內(nèi)容重復 利用這一點可以實現(xiàn) 題目的要求 XOR DX DX XOR AX AX MOV CX 4 L1 SHR BL 1 RCR AX 1 SAR AX 1 SAR AX 1 SAR AX 1 LOOP L1 MOV CX 4 L2 SHR BL 1 RCR DX 1 SAR DX 1 SAR DX 1 SAR DX 1 LOOP L2 18 字變量 VAR1 中保存有小于 38250 的 16 位無符號數(shù) 編寫程序段實現(xiàn) VAR1 150 并 進行四舍五入操作 將商保存在字節(jié)變量 VAR2 中 解 根據(jù)題意 38250 150 255 因此商不會超過 255 可以用一個字節(jié)表示 a b 的四舍五入操作可以通過判斷除后余數(shù)實現(xiàn) 余數(shù)大于等于除數(shù)的一半 則商加 1 否則不用加 1 但這種方法用匯編語言編程實現(xiàn)時比較復雜 這里介紹另外一種方法 設 a b 的四舍五入后的結果為 c 用 表示取整數(shù)操作 則 2 0 5 b a a c bb 這種方法是在除法操作之前 在被除數(shù)上加上除數(shù)的一半 這樣除法操作后得到的值就是考 慮了四舍五入的商 VAR1 DW 12345 VAR2 DB DATAA DB 150 MOV AX VAR1 XOR BX BX MOV BL DATAA SHR BX 1 ADD AX BX DIV DATAA MOV VAR2 AL 19 有一組無符號的 16 位數(shù)據(jù)保存在 BUFFER 中 前兩個字節(jié)存放數(shù)據(jù)的個數(shù) 編程實現(xiàn) 按下式進行濾波處理 1 1 2 2 3 2 y kx kx kx kk y kx kk 解 濾波結果保存在 FILT 中 BUFFER DW 0CH DW 33H 18H 1BH 06H 33H 08H DW 3H 6H 0FH 51H 05H 0CH FILT DW 100H DUP LEA SI BUFFER LEA DI FILT MOV CX SI MOV DI CX ADD SI 2 ADD DI 2 XOR DX DX MOV AX SI MOV DI AX MOV BX 2 SI MOV 2 DI BX ADD SI 4 ADD DI 4 DEC CX DEC CX ADD AX BX ADC DX 0 MOV BX 3 L1 ADD AX SI ADC DX 0 PUSH DX PUSH AX DIV BX MOV DI AX POP AX POP DX SUB AX SI 4 SUBB DX 0 ADD DI 2 ADD SI 2 LOOP L1 20 在由字符串構成的緩沖區(qū) BUFFER 中 前 2 個字節(jié)存放字符個數(shù) 后續(xù)每個字節(jié)存放 一個字符的 ASCII 碼 編寫程序?qū)崿F(xiàn)將字符串 2004 替換成 2006 解 在數(shù)據(jù)段中定義 BUFFER DW 74 DB This year is 2004 In 2004 we have a plan for reducing annual expensive 10 DEST DB 2004 在代碼段中編寫程序段 CLD LEA SI BUFFER MOV CX SI ADD SI 2 LEA DI DEST L1 PUSH SI PUSH DI PUSH CX MOV CX 4 REPZ SCASB JNZ L2 MOV BYTE PTR SI 1 6 L2 POP CX POP DI POP SI INC SI INC DI LOOP L1 21 定義有下列宏指令 WAGS MACRO S1 S2 S3 SUB AX AX MOV DX AX ADD AX S1 ADD AX S2 ADC DX 0 ADD AX S3 ADC DX 0 ENDM 當采用宏調(diào)用指令 WAGS 60000 25000 3000 時 執(zhí)行后 DX AX 解 宏指令 WAGS 完成的功能為 S1 S2 S3 結果放在 DX AX 中 所以 調(diào)用 WAGS 60000 25000 3000 時 其結果為 DX 0001H AX 57C0H 22 對上題定義的宏指令 如果采用宏調(diào)用指令 WAGS BX CX SI 時 寫出宏展開形式 解 調(diào)用 WAGS BX CX SI 時 宏展開形式 SUB AX AX MOV DX AX ADD AX BX ADD AX CX ADC DX 0 ADD AX SI ADC DX 0 23 寫出宏指令 SUMMING 實現(xiàn)將字節(jié)緩沖區(qū) array 中的內(nèi)容求校驗和 保留低 8 位 并保存在 VALUE 中 解 設 array 前兩個字節(jié)保存緩沖區(qū)字節(jié)數(shù) 在宏指令 SUMMING 將 array 和 VALUE 作為 形式參數(shù) SUMMING MACRO array VALUE LEA SI array MOV CX SI ADD SI 2 XOR AL AL L1 ADD AL SI INC SI LOOP L1 MOV VALUE AL ENDM 第 4 章 匯編語言程序設計 1 已知在 BUF 的起始處保存有 N 個字符的 ASCII 碼 編寫匯編語言程序?qū)崿F(xiàn) 將這組字 符串傳送到緩沖區(qū) BUFR 中 并且使字符串的順序與原來的順序相反 解 BUF DB BONJOUR BELLE BUFR DB 100 DUP MOV CX N LEA SI BUF LEA DI BUFR ADD DI CX DEC DI L1 MOV AL SI MOV DI AL INC SI DEC DI LOOP L1 2 利用移位 傳送和相加指令實現(xiàn) AX 的內(nèi)容擴大 10 倍 解 將擴大后的結果放在 DX AX 中 注意到 10 AX 8 AX 2 AX XOR DX DX SHL AX 1 RCL DX 1 MOV BX AX MOV CX DX SHL AX 1 RCL DX 1 SHL AX 1 RCL DX 1 ADD AX BX ADC DX CX 3 在緩沖區(qū)VAR中連續(xù)存放著3個16位的無符號數(shù) 編寫程序?qū)崿F(xiàn)將其按遞增關系排列 如果 VAR 中保存的為有符號數(shù) 則再編寫程序?qū)崿F(xiàn)將其按遞減關系排列 解 VAR DW 1236 432 3900 XOR SI SI MOV AX VAR SI CMP AX VAR SI 2 JAE L1 XCHG AX VAR SI 2 L1 CMP AX VAR SI 4 JAE L2 XCHG AX VAR SI 4 L2 MOV VAR SI AX MOV AX VAR SI 2 CMP AX VAR SI 4 JAE L3 XCHG AX VAR SI 4 L3 MOV VAR SI 2 AX 4 編寫程序段實現(xiàn)將 AL 和 BL 中的每一位依次交叉 得到的 16 位字保存在 DX 中 例 如 AL 01100101B BL 11011010B 則得到的 DX 10110110 10011001B 解 利用移位指令完成 XOR DX DX MOV CX 8 L1 SHR AL 1 RCR DX 1 SHR BL 1 RCR DX 1 LOOP L1 5 在變量 VAR1 和 VAR2 中分別保存有兩個字節(jié)型的正整數(shù) 編寫完整的匯編語言程序?qū)?現(xiàn) 1 當兩數(shù)中有一個奇數(shù)時 將奇數(shù)存入 VAR1 偶數(shù)存入 VAR2 2 當兩數(shù)均為奇數(shù)時 兩個變量的內(nèi)容不變 3 當兩數(shù)均為偶數(shù)時 兩數(shù)縮小一倍后存入原處 解 當 VAR1 為奇數(shù)時 不論 VAR2 的奇偶性 這兩個單元的內(nèi)容均不變 只有當 VAR1 為偶數(shù)時 如果 VAR2 為奇數(shù) 則 VAR1 與 VAR2 內(nèi)容交換 如果 VAR2 為偶數(shù) 則兩數(shù)縮 小一倍后存入原處 DATA SEGMENT VAR1 DB 28 VAR2 DB 36 DATA ENDS CODE SEGMENT ASSUME CS CODE DS DATA ES DATA START MOV AX DATA MOV DS AX MOV ES AX MOV AL VAR1 MOV BL VAR2 TEST AL 1 JZ EVEN1 JMP OVER EVEN1 TEST BL 1 JZ EVEN2 MOV VAR1 BL MOV VAR2 AL JMP OVER EVEN2 SHR AL 1 MOV VAR1 AL SHR BL 1 MOV VAR2 BL OVER MOV AH 4CH MOV AL 0 INT 21H CODE ENDS END START 6 已知在字變量 VAR1 VAR2 和 VAR3 中保存有 3 個相同的代碼 但有一個錯碼 編寫 程序段找出這個錯碼 并將它送到 AX 其地址送 SI 如果 3 個代碼都相同 則在 AX 中置 1 標志 解 在數(shù)據(jù)段中定義 VAR1 DW 5A34H VAR2 DW 5A35H VAR3 DW 3A34H 在代碼段中編寫程序段 MOV AX 1 MOV BX VAR1 CMP BX VAR2 JZ L2 CMP BX VAR3 JZ L1 MOV AX BX LEA SI VAR1 JMP OVER L1 MOV AX VAR2 LEA SI VAR2 JMP OVER L2 CMP BX VAR3 JZ OVER MOV AX VAR3 LEA SI VAR3 OVER 7 分析下列程序段的功能 MOV CL 04 SHL DX CL MOV BL AH SHL AX CL SHR BL CL OR DL BL 解 程序段完成 DX AX 組成的 32 位無符號數(shù)左移 4 位 低位補零 也即除以 16 8 下列程序段執(zhí)行后 求 BX 寄存器的內(nèi)容 MOV CL 3 MOV BX 0B7H ROL BX 1 ROR BX CL 解 實際上完成 BX 內(nèi)容循環(huán)右移 2 位 因此 BX 寄存器的內(nèi)容為 C02DH 9 下列程序段執(zhí)行后 求 BX 寄存器的內(nèi)容 MOV CL 5 MOV BX 7D5CH SHR BX CL 解 完成 BX 內(nèi)容邏輯右移 5 位 因此 BX 寄存器的內(nèi)容為 03EAH 10 將 BUFFERS 中 N 個字按相反順序傳遞到 BUFFERT 中 解 LEA SI BUFFERS LEA DI BUFFERT MOV CX N ADD DI N ADD DI N SUB DI 2 L1 MOV AX SI MOV DI AX ADD SI 2 SUB DI 2 LOOP L1 11 數(shù)組 ARRAY 中存放有一組字型數(shù)據(jù) 前兩個字節(jié)存放數(shù)據(jù)長度 5 的倍數(shù) 為給這 個數(shù)組中的數(shù)據(jù)進行加密保護 每 5 個數(shù)據(jù)取出一個數(shù)據(jù)進行加密處理 奇數(shù)位進行取 反 偶數(shù)位不變 例如對數(shù)據(jù) 0110 1100 1011 0001B 加密后變成 1100 0110 0001 1011B 編寫加密程序 encrpytion 和解密程序 unencrpytion 解 約定從第一個數(shù)據(jù)開始 每 5 個數(shù)據(jù)為一組 每組中的第一個數(shù)據(jù)采取加密 解密處理 由于加密算法采用的是取反操作 解密算法也采用取反操作 因此解密和解密算法是同一個 程序 ENCRPYTION PROC NEAR LEA SI ARRAY XOR DX DX MOV AX SI MOV BX 5 DIV BX MOV CX AX ADD SI 2 L1 MOV AX SI XOR AX 0AAAAH MOV SI AX ADD SI 10 LOOP L1 RET ENCRPYTION ENDP 13 設 BUF 中存放有 N 個無符號數(shù) 或有符號數(shù) 編程實現(xiàn)求它們的最小值 存入 AX 和最大值 存入 DX 解 BUF 存放有 N 個無符號數(shù)的程序如下 MOV CX N LEA SI BUF MOV AX SI MOV DX AX ADD SI 2 L1 CMP AX SI JBE NOCHG1 XCHG AX SI NOCHG1 CMP DX SI JAE NOCHG2 XCHG DX SI NOCHG2 ADD SI 2 LOOP L1 如果 BUF 中存放的是有符號數(shù) 則只需要將程序中的兩行內(nèi)容修改 JBE NOCHG1 改成 JLE NOCHG1 JAE NOCHG2 改成 JGE NOCHG2 14 設 BUFFER 中存放有 N 個無符號 第 1 個字節(jié)存放緩沖區(qū)的長度 編程實現(xiàn)將其中的 0 元素抹去 并更新其長度 解 設 BUFFER 中存放的是字節(jié)型數(shù)據(jù) 采用雙指針方法 SI 為讀指針 DI 為寫指針 從低地址開始 內(nèi)存中讀出一個字節(jié) 如果不為 0 則寫入內(nèi)存 如果為 0 則不進行寫操 作 LEA SI BUFFER XOR CX CX MOV CL SI INC SI MOV DI SI XOR BH BH XOR AL AL L1 CMP SI AL JZ L2 MOV BL SI MOV DI BL INC DI INC BH L2 INC SI LOOP L1 MOV BUFFER BH 16 編寫一個子程序?qū)崿F(xiàn)統(tǒng)計 AL 中 1 的個數(shù) 然后檢測出字節(jié)型緩沖區(qū) BUF 中 0 和 1 個 數(shù)相等的元素個數(shù) 解 統(tǒng)計 AL 中 1 的個數(shù) 只需將 AL 右移 移出的一位內(nèi)容進行累加 子程序為 COUNTBYTE PROC NEAR PUSH AX PUSH CX MOV CX 8 XOR BL BL COU1 SHR AL 1 ADC BL 0 LOOP COU1 POP CX POP AX RET COUNTB

溫馨提示

  • 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

提交評論