离丶dong子 发表于 2012-4-25 15:45:54

汇编第六章我遇到两次这个问题了, push cs:[bx] 这里一直push到第5个字活着第六个字

assume cs:code
code segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cdddh,0985h
dw 0,0,0,0,0,0,0,0
dong:mov ax,cs
   mov ss,ax
mov sp,32
mov bx,0
mov cx,8
s:   push cs:
   add bx,2
loop s

mov bx,0
mov cx,8
s0:pop cs:
   add bx,2
loop s0

mov ax,4c00h
int 21h
code ends
end dong


汇编第六章我遇到两次这个问题了, push cs:这里一直push到第5个字活着第六个字后面的数据完全对不上,谁能试一下,思路我现在是大概都理解了,就是运行起来答案不一致的问题,有明白的老师,师兄多谢了,新手求调教!



欲速则不达 发表于 2012-4-25 15:45:55

栈顶位置错误,前面32个字节是数据,后面32个字节才是你本来想设置的栈吧,你把空栈顶设置在第32个字节处,前面四个数据入栈后,刷新了后面四个数据所占据的内存空间,当然出错了。试试把sp=64

箪v箪 发表于 2012-4-25 17:29:13

0cddd是没错的,第一位是字母的话前面必须加0

ztc123 发表于 2012-4-25 18:16:29

你看错了吧,PUSH 我运行能复制额

づ花败相惜╮ 发表于 2012-4-25 19:44:23

我也复制过去了,然后开始不是应该 要先 mov ax,code ?????
我是初学者

_作业 发表于 2012-4-25 20:33:10

没明白你说的意思

_作业 发表于 2012-4-25 20:34:13

在说的明白些

①束旸銧 发表于 2012-4-26 11:49:09

你这个运行后 CS:0~15的数据反转过来了!你想要什么结果?

离丶dong子 发表于 2012-4-26 14:37:42

感谢大家啊,我懂了,是我迷糊了。希望同学们不会被我误导!

离丶dong子 发表于 2012-4-26 14:51:36



这是push之后还没出栈的时候,原来数据段的后半部分被改变了,我昨天就纠结的这里,他是被什么改变了?是数据进栈后这里的值就会变,还是其他地方进来的,?

eet_you 发表于 2012-4-28 01:24:42

{:1_1:}还没有人知道~ 等待答案
页: [1]
查看完整版本: 汇编第六章我遇到两次这个问题了, push cs:[bx] 这里一直push到第5个字活着第六个字