监测点6.1
检测点6.1(1)下面的程序实现依次用内存0:0~0:15单元中的内容改写程序中的数据,完成程序:
assume cs:codesg
codesg segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
start:mov ax,0
mov ds,ax
mov bx,0
mov cx,8
s:mov ax,
mov cs:,ax ————————————————————————————————————————————————————————————————————————
add bx,2
loop s
mov ax,4c00h
int 21h
codesg ends
end start
检测点6.1
(2)下面的程序实现依次用内存0:0~0:15单元中的内容改写程序中的数据,数据的传送用栈来进行。栈空间设置在程序内。完成程序:
assume cs:codesg
codesg segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,09 87h
dw 0,0,0,0,0,0,0,0,0,0
start:mov ax, codesg ;或mov ax, cs————————————————————————————————————————————————————————————————————
mov ss,ax
mov sp, 24h ;或mov sp, 36 ;(第一版填1ah或26)
mov ax,0
mov ds,ax
mov bx,0
mov cx,8
s:push
pop cs: ;或 pop ss: ————————————————————————————————————————————————————————————————————————
add bx,2
loop s
mov ax,4c00h
int 21h
codesg ends
end sta
****************************************
划横线的三个地方都不是很懂 也有回去看堆栈的视频还是不很理解
1.mov cs:,ax内存单元改写程序数据,为什么要是CS: 而不是其他
2.mov ax,cs为什么要把cs的偏移地址传递给SS而不直接0000h或者其他
3.popss: 到底是在在哪一个地址操作的,操作了哪一个数。比如BX=0;10个空间的堆栈SS:不是指堆栈最上面的吗。可是上面是空的 0123不是在下面的ss:里面吗。 1 程序开头的第一句assume cs:codesg,也就是说codesg开始的位置就是cs寄存器指向的位置,
且bx用来控制下标,故用ax做中转,最终根据题目意思:改写程序中的数据,所以就填cs:
2 ss是栈段寄存器,题目说了“栈空间设置在程序内”,也就是10个0的那段区域,所以栈段要设置在和cs段一样的地方
3 前一句的push,可以看ss:sp,指向的是栈底也就是最后一个0的地方,先push进去,然后pop到cs:的地方
页:
[1]