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
结果如下: