这本书购于2015.11.30,我大概从2016.3月开始读,历时大概三个月,我们学校开《微机原理与汇编语言》这门课,不过让人感觉很不爽,课本一开始就丢给你一堆东西,意欲让你记住这一大堆东西,然后开始编程,我对编程语言的学习方面要求比较高,所以开始读这本王爽老师写的汇编语言,目前为止,这本书给我的感觉就是,你能学到很多底层的东西,尤其是像键盘的读写原理,屏幕的显示,特别是对内存的操作和管理,不像课本上给你一个中断让你就能显示字符之类的,它会一步一步教你怎么把要显示的东西写到显存里面,这本书显得比较浅显易懂,让人感觉不错,特别是读了这本书再去看那些难度较高的汇编代码及微机原理,效率会高很多,下面是我读这本书的过程中对书中检测点的解答,仅代表个人观点。
第一章
检测点1.1
1) 13
(8kb = 8 * 1024 = 2^13)
2) 1024 0 1023
3) 8*1024 1024
(1 byte = 8 bit,计算机以byte为存储单位)
4) 1024^3 1024^2 1024
5) 2^6 1 2^4 2^2
(kb = 2^10 Mb = 2^20 Gb = 2^30)
6) 1 1 2 2 4
7) 512 256
(8086的寄存器为16位寄存器,一次可以读取两个字节,80386为32位寄存器)
8) 二进制
第二章
检测点2.1
1)
AX = F4A3h
AX = 31A3h
AX = 3123h
AX = 6246h
BX = 826Ch
CX = 6246h
AX = 826Ch
AX = 04D8h
AX = 0482h
AX = 6C82h
AX = D882h
AX = D888h
AX = D810h
AX = 6246h
2)
mov ax,2
add ax,ax
add ax,ax
add ax,ax
检测点2.2
1)00010h 1000fh
(0001h+0000h 0001h+ffffh)
2)1001h 2000h
(偏移地址的范围为0000-ffff,内存单元=段地址*16+偏移地址,当偏移地址最小时,段地址最大,偏移地址最大时,段地址最小)
检测点2.3
4次修改IP,最后IP为0
第三章
检测点3.1
1)
mov ax,1
mov ds,ax
mov ax,[1000] AX = 2662h
mov bx,[1001] BX = E626h
mov ax,bx AX = E626h
mov ax,[0000] AX = 2662h
mov bx,[0002] BX = D6E6h
add ax,bx AX = FD48h
add ax,[0004] AX = 2C14h
mov ax,0 AX = 0000h
mov al,[0002] AX = 00E6h
mov bx,0 BX = 0000h
mov bl,[000C] BX = 0026h
add al,bl AX = 000Ch
2)
CS = 2000h,IP = 0,DS = 1000h
mov ax,6622h AX = 6622h
jmp 0ff0:0100h CS = 0ff0 IP = 0100h
mov ax,2000h AX = 2000h
mov ds,ax DS = 2000h
mov ax,[0008] AX = C389h
mov ax,[0002] AX = EA66h
mov ax,6622h AX = 6622h
数据和程序表达上没有区别,只跟存储的地方有关,存在数据段中即为数据,存在程序段中就是程序
检测点3.2
1)
mov ax,2000h
mov ss,ax
mov sp,10h
2)
mov ax,1000h
mov ss,ax
mov sp,0
第六章
检测点6.1
1)
mov cs:[bx],ax
2)
cs
26或1ah
pop cs:[bx]
第九章
检测点9.1
1)
db 8 dup (0)
2)
offset start
cs
3)
CS = 0006h IP = 00BE
检测点9.2
mov cl,[bx]
mov ch,0
jcxz ok
inc bx
检测点9.3
inc cx
(因为loop s执行时是先将cx减一再与0比较)
第十章
检测点10.1
1000
0000
检测点10.2
ax = 3
检测点10.3
ax = 1006
检测点10.4
ax = 9
(call ax时将IPpush到栈中,也就是push 3)
检测点10.5
1)
ax = 3
2)
ax = 0001 bx = 0000
第十一章
检测点11.1
1 1 0
1 1 0
1 1 0
1 1 0
0 0 0
0 1 0
0 1 0
检测点11.2
0 0 0 1 1
0 0 0 1 1
0 0 1 0 0
0 0 1 0 0
1 1 0 1 1
1 1 0 1 1
1 0 0 0 0
1 0 0 0 0
0 1 1 0 1
检测点11.3
1)
jna s0
jna s0
2)
jb s0
jb s0
检测点11.4
ax = 0871h
检测点12.1
1)
039D:0016
2)
0000:[4N]
0000:[4N+2]
检测点13.1
assume cs:code,ds:data
data segment
db 'conversation',0
data ends
code segment
start: mov ax,cs
mov ds,ax
mov si,offset show
mov ax,0
mov es,ax
mov di,200h
mov cx,offset showend-offset show
cld
rep movsb
mov ax,0
mov es,ax
mov word ptr es:[7ch*4],200h
mov word ptr es:[7ch*4+2],0
mov ax,data
mov ds,ax
mov si,0
mov ax,0b800h
mov es,ax
mov di,12*160
s: cmp byte ptr [si],0
je ok
mov al,[si]
mov es:[di],al
mov al,2
mov es:[di+1],al
inc si
add di,2
mov bx,offset s-offset ok
int 7ch
ok: mov ax,4c00h
int 21h
show: push bp
mov bp,sp
add [bp+2],bx
pop bp
iret
showend:nop
code ends
end start
检测点13.2
1)
错误,不能向BIOS中写程序
2)
错误,19h中断在操作系统以前,而DOS由操作系统控制即在操作系统以后
检测点14.1
1)
mov al,2
out 70h,al
in al,71h
2)
mov al,0
out 71h,al
mov al,2
in 70h,al
检测点14.2
在不考虑溢出的情况下:
mov ax,__
mov bx,ax
shl bx,1
mov cl,3
shl ax,cl
add ax,bx
第十五章
检测点15.1
1)
pushf
call dword ptr ds:[0]
2)
在中断向量表中设置新的int9中断入口地址的时候不让其发生中断,即
cli
mov word ptr es:[9*4],offset int9
mov word ptr es:[9*4+2],cs
sti
恢复中断向量表int9的源地址时同理:
cli
push ds:[0]
pop es:[9*4]
push ds:[2]
pop es:[9*4+2]
sti
第十六章
检测点16.1
a[si]
b
b
1
检测点16.2
mov ax,data
mov es,ax
第十七章
检测点17.1
IF = 1 DI(disable interupt)
IF = 0 EI(enable interupt)
当执行int16中断时是从缓冲区中读出字符,若缓冲区为空,则int16应该可以响应int9的中断,故IF不一定为1
来源:oschina
链接:https://my.oschina.net/u/4273197/blog/4319278