/// .     
1.1    用降幂法和除法将下列十进制数转换为二进制数和十六进制数:
(1) 369                (2) 10000                (3) 4095                (4) 32767
答:(1)  369=1 0111 0001b=171h
(2)  10000=10 0111 0001 0000b=2710h
(3)  4095=1111 1111 1111b=fffh
(4)  32767=111 1111 1111 1111b=7fffh
1.2    将下列二进制数转换为十六进制数和十进制数:
(1) 10 1101            (2) 1000 0000            (3) 1111 1111 1111 1111    (4) 1111 1111
答:(1)  10 1101b=2dh=45
(2)  1000 0000b=80h=128
(3)  1111 1111 1111 1111b=ffffh=65535
(4)  1111 1111b=ffh=255
1.3    将下列十六进制数转换为二进制数和十进制数:
(1) fa                (2) 5b                (3) fffe                (4) 1234
答:(1)  fah=1111 1010b=250
(2)  5bh=101 1011b=91
(3)  fffeh=1111 1111 1111 1110b=65534
(4)  1234h=1 0010 0011 0100b=4660
1.4    完成下列十六进制数的运算,并转换为十进制数进行校核:
(1) 3a+b7            (2) 1234+af            (3) abcd-fe            (4) 7ab×6f
答:(1)  3a+b7h=f1h=241
(2)  1234+afh=12e3h=4835
(3)  abcd-feh=aacfh=43727
(4)  7ab×6fh=35325h=217893
1.5    下列各数均为十进制数,请用8位二进制补码计算下列各题,并用十六进制数表示其运算结果。
(1) (-85)+76    (2) 85+(-76)    (3) 85-76    (4) 85-(-76)    (5) (-85)-76    (6) -85-(-76)
答:(1) (-85)+76=1010 1011b+0100 1100b=1111 0111b=0f7hcf=0of=0
(2) 85+(-76)=0101 0101b+1011 0100b=0000 1001b=09hcf=1of=0
(3) 85-76=0101 0101b-0100 1100b=0101 0101b+1011 0100b=0000 1001b=09hcf=0of=0
(4) 85-(-76)=0101 0101b-1011 0100b=0101 0101b+0100 1100b=10100001b=0a1hcf=0of=1
(5) (-85)-76=1010 1011b-0100 1100b=1010 1011b+1011 0100b=0101 1111b=5fhcf=0of=1
(6) -85-(-76)=1010 1011b-1011 0100b=1010 1011b+0100 1100b=11110111b=0f7hcf=0of=0
1.6    下列各数为十六进制表示的8位二进制数,请说明当它们分别被看作是用补码表示的带符号数或无符号数时,它们所表示的十进制数是什么?
(1) d8                (2) ff
答:(1)  d8h表示的带符号数为 -40d8h表示的无符号数为216
(2)  ffh表示的带符号数为 -1 ffh表示的无符号数为255
1.7    下列各数均为用十六进制表示的8位二进制数,请说明当它们分别被看作是用补码表示的数或字符的ascii码时,它们所表示的十进制数及字符是什么?
(1) 4f                (2) 2b                (3) 73                (4) 59
答:(1)  4fh表示的十进制数为 794fh表示的字符为o
(2)  2bh表示的十进制数为 432bh表示的字符为 +
(3)  73h表示的十进制数为11573h表示的字符为s
(4)  59h表示的十进制数为8959h表示的字符为y
1.8    请写出下列字符串的ascii码值。
for example,
this is a number 3692.
汇编指令有多少个
答:46h  6fh  72h  20h  65h  78h  61h  6dh  70h  6ch  65h  2ch  0ah  0dh
54h  68h  69h  73h  20h  69h  73h  20h  61h  20h  6eh  75h  6dh  62h  65h  72h  20h  33h  36h  39h  32h  2eh  0ah  0dh
.     
2.1    80x86微机的输入/输出指令中,i/o端口号通常是由dx寄存器提供的,但有时也可以在指令中直接指定00~ffh的端口号。试问可直接由指令指定的i/o端口数。
答:可直接由指令指定的i/o端口数为256个。
2.2    有两个16位字1ee5h2a3ch分别存放在80x86微机的存储器的000b0h000b3h单元中,请用图表示出它们在存储器里的存放情况。
答:存储器里的存放情况如右上图所示。
2.3    ibm pc机的存储器中存放信息如右下图所示。试读出30022h30024h字节单元的内容,以及30021h30022h字单元的内容。
答:30022h字节单元的内容为abh30024h字节单元的内容为efh30021h字单元的内容为ab34h30022h字单元的内容为cdabh
2.4    在实模式下,段地址和偏移地址为3017:000a的存储单元的物理地址是什么?如果段地址和偏移地址是3015:002a3010:007a呢?
答:3017:000a3015:002a3010:007a的存储单元的物理地址都是3017ah
2.5    如果在一个程序开始执行以前(cs)=0a7f0h(16进制数的最高位为字母,则应在其前加一个0) (ip)=2b40h,试问该程序的第一个字的物理地址是多少?
答:该程序的第一个字的物理地址是0aaa40h
2.6    在实模式下,存储器中每一段最多可有10000h个字节。如果用调试程序debugr命令在终端上显示出当前各寄存器的内容如下,请画出此时存储器分段的示意图,以及条件标志ofsfzfcf的值。
c>debug
-r
ax=0000  bx=0000  cx=0079  dx=0000  sp=ffee  bp=0000
si=0000  di=0000  ds=10e4  es=10f4  ss=21f0  cs=31ff 
ip=0100  nv  up  di  pl  nz  na  po  nc
答:此时存储器分段的示意图如右图所示。ofsfzfcf的值都为0
2.7    下列操作可使用那些寄存器?
(1) 加法和减法                    数据寄存器等
(2) 循环计数                        cx
(3) 乘法和除法    axdx,乘数和除数用其他寄存器或存储器
(4) 保存段地址                    段寄存器
(5) 表示运算结果为0                zf=1
(6) 将要执行的指令地址            cs:ip
(7) 将要从堆栈取出数据的地址        ss:sp
答:答案见题目的右边。
2.8    那些寄存器可以用来指示存储器地址?
答:bxbpsidi、堆栈操作时的sp、对应的段地址、386及其后继机型的exx
2.9    请将下列左边的项和右边的解释联系起来(把所选字母放在括号中)
(1)  cpu        (m)        a.保存当前栈顶地址的寄存器。
(2)  存储器        (c)        b.指示下一条要执行的指令的地址。
(3)  堆栈        (d)        c.存储程序、数据等信息的记忆装置,微机有ramrom两种。
(4)  ip            (b)        d.以后进先出方式工作的存储空间。
(5)  sp            (a)        e.把汇编语言程序翻译成机器语言程序的系统程序。
(6)  状态标志    (l)        f.唯一代表存储空间中每个字节单元的地址。
(7)  控制标志    (k)        g.能被计算机直接识别的语言。
(8)  段寄存器    (j)        h.用指令的助记符、符号地址、标号等符号书写程序的语言。
(9)  物理地址    (f)        i.把若干个模块连接起来成为可执行文件的系统程序。
(10) 汇编语言    (h)        j.保存各逻辑段的起始地址的寄存器,8086/8088机有四个:csds
sses
(11) 机器语言    (g)        k.控制操作的标志,如df位。
(12) 汇编程序    (e)        l.记录指令操作结果的标志,共6位:ofsfzfafpfcf
(13) 连接程序    (i)        m.分析、控制并执行指令的部件,由算术逻辑部件alu和寄存器等
组成。
(14) 指令        (o)        n.由汇编程序在汇编过程中执行的指令。
(15) 伪指令        (n)        o.告诉cpu要执行的操作(一般还要指出操作数地址),在程序运行时
执行。
答:答案见题目的括号中。
.     
3.1    给定(bx)=637dh(si)=2a9bh,位移量d=7237h,试确定在以下各种寻址方式下的有效地址是什么?
(1) 立即寻址
(2) 直接寻址
(3) 使用bx的寄存器寻址
(4) 使用bx的简接寻址
(5) 使用bx的寄存器相对寻址
(6) 基址变址寻址
(7) 相对基址变址寻址
答:(1) 操作数在指令中,即立即数;
(2) ea=d=7237h
(3) ea,操作数为(bx)=637dh
(4) ea=(bx)=637dh
(5) ea=(bx)+d=0d5b4h
(6) ea=(bx)+(si)=8e18h
(7) ea=(bx)+(si)+d=1004fh;超过了段的边界,最高进位位丢失,因此ea=004fh
3.2    试根据以下要求写出相应的汇编语言指令
(1) bx寄存器和dx寄存器的内容相加,结果存入dx寄存器中。
(2) 用寄存器bxsi的基址变址寻址方式把存储器中的一个字节与al寄存器的内容相加,并把结果送到al寄存器中。
(3) 用寄存器bx和位移量0b2h的寄存器相对寻址方式把存储器中的一个字和(cx)相加,并把结果送回存储器中。
(4) 用位移量为0524h的直接寻址方式把存储器中的一个字与数2a59h相加,并把结果送回存储单元中。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。