《微型计算机原理与接口技术》实验报告 一、程序设计 题目一 三十二位无符号乘法 1 设计分析: (1)程序设计任务: 用十六位乘法指令完成三十二位无符号数乘法(结果 64 位)。 使用 MUL 指令,完成双字无符号数乘法程序,要求乘数和被 乘数从键盘输入,结果显示于屏幕上。 (2)程序设计要求: 1)从键盘输入两个乘数(十六进制) 2)结果显示于屏幕上(十六进制) (3)程序设计过程: 1) 定义数据段用于开辟缓冲区存储输入数据、输出数据和乘积。 2)从键盘分别输入两个八位数字符(三十二字节)存入缓冲区(分 4 次输入,每次输入4 个字符,前两次为被乘数的高位与低位,后两次为乘数的高位与低位) 3)对缓冲区输入的字符进行处理,让 As cal 码转换为数值本身的数值。 4)把三十二位分割成两位十六位,分别对其进行十六位的乘法。 5)将四个十六位乘法的乘积按照各自的位相加的最终乘积 6)对所得结果进行处理,让 As cal 码转换为数值本身的数值 7)将结果向屏幕输出。 2、算法(一个框代表 16 位 2 进制数) 3、 X2 X1 y2 y1 P+6 p+4 p+2 p 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 16 4、 程序流程图: 开始 初始化 输入被乘数的 高位的 4 个字符 X2 输入被乘数的 低位的 4 个字符 X1 输入乘数的 高位的 4 个字符 y2 输入乘数的 低位的 4 个字符 y1 开始运算乘法 被乘数低位 4 个字符 x1 和 乘数低位 4 个字符 y1 相乘结果低位存入 p,高位存入 p+2 被乘数高位 4 个字符 x2 和 乘数低位 4 个字符 y1 相乘 结果低位存入 p+2,高位存入p+4 被乘数低位 4 个字符 x1 和 乘数高位 4 个字符 y2 相乘 结果低位存入 p+2,高位存入p+4 被乘数高位 4 个字符 x2 和 乘数高位 4 个字符 y2 相乘 结果低位存入 p+4,高位存入p+6 5、 测试数据与运行结果: 输入被乘数的高位的 4 个字符 X2: 输入被乘数的低位的 4 个字符 X1: 乘积相加 输出结果 输入乘数的高位的4 个字符 y2: 输入乘数的低位的4 个字符 y1: 运行结果: 6、 程序源代码及注解: ddata segment x1 dw 16 dup(?) x2 dw 16 dup(?) y1 dw 16 dup(?) y2 dw 16 dup(?) p dw 30 dup(?) keybuf db 10 dup(?) ddata ends ; 定义数据段 ccode segment assume cs:ccode,ds:ddata start:mov ax,d...