2、编程,完成问题7.9中的程序
这里就直接贴出代码了。其实就是运用基址变址来使自己的位置不停变化,只要能徒手敲出实验6.1的问题,6.2也就没有问题了。
assume cs:codesg,ss:stacksg,ds:datasg
stacksg segment
dw 0,0,0,0,0,0,0,0
stacksg ends
datasg segment
db '1. display '
db '2. brows '
db '3. replace '
db '4. modify '
datasg ends
codesg segment
start:
mov ax,stacksg
mov ss,ax
mov sp,16 ;定义栈段
mov ax,datasg
mov ds,ax
mov bx,0 ;将bx指向了数据段
mov cx,4 ;外部循环4次
s0: mov si,3
push cx
mov cx,4 ;内部循环4次
s1:
mov al,[bx+si]
and al,11011111b
mov [bx+si],al
;and [bx+si],11011111b 这样写是错的,因为不知道他的长度大小,你可以自学下一章的第二节来做,也可以用寄存器
inc si
loop s1
pop cx ;还原cx
add bx,16 ;将bx指向下一行
loop s0
mov ax,4c00h
int 21h
codesg ends
end start结果如下:

290

被折叠的 条评论
为什么被折叠?



