| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 921 人关注过本帖
标题:栈顶问题
只看楼主 加入收藏
】无极【
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-5-14
结帖率:0
收藏
已结贴  问题点数:20 回复次数:6 
栈顶问题
书上(《汇编语言》)试验五.3 中有段代码看不明白:
assume ds:data,ss:stack,cs:code
data segment
    dw 0123h,0456h
data ends

stack segment
    dw 0,0     //这里开辟了2个字的内存空间(即4个字节)
stack ends

code segment
start: mov ax,stack
       mov ss,ax
       mov sp,16  //问题,书上栈顶指向ss:sp 16,我理解应该ss:sp应该指向4才对啊,可是我改后运行却运行出错,不知为何?
……
……
code ends
end start
搜索更多相关主题的帖子: 空间 start 
2010-07-06 08:49
东海一鱼
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:48
帖 子:757
专家分:4760
注 册:2009-8-10
收藏
得分:20 
你忘了一点,栈是'倒置'的。也就是说栈的位置在一个‘段‘的尾部,并向下发展。
你可以用debug好好观察一下它的动作、行为。

举世而誉之而不加劝,举世而非之而不加沮,定乎内外之分,辩乎荣辱之境,斯已矣。彼其于世未数数然也。
2010-07-06 08:54
】无极【
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-5-14
收藏
得分:0 
回复 2楼 东海一鱼
这个我应该没有理解错啊,push入栈时sp是做减法的 ,pop出栈 sp是做加法的,比如 把ss:0000h~ss:0004h设为栈,那空栈时sp不是应该指向ss:0004h处吗?但书上却把栈顶sp设为16处,应该属于越栈现象啊,但是运行却不会出错。我把sp指向栈底,运行却出错。不知为何道理
2010-07-06 10:11
东海一鱼
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:48
帖 子:757
专家分:4760
注 册:2009-8-10
收藏
得分:0 
栈空间大小和栈顶指针是两个概念。你的sp指向0004时,实际上只有一个word的空间可用。下面的那个是越界标示(溢出)。

[ 本帖最后由 东海一鱼 于 2010-7-6 10:58 编辑 ]

举世而誉之而不加劝,举世而非之而不加沮,定乎内外之分,辩乎荣辱之境,斯已矣。彼其于世未数数然也。
2010-07-06 10:38
】无极【
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-5-14
收藏
得分:0 
谢谢 老师  俺在去啃啃书去
 原来栈空间大小和栈指针 是两码事啊
还有 sp=0004 应该等于2个word空间吧

[ 本帖最后由 】无极【 于 2010-7-6 11:23 编辑 ]
2010-07-06 11:06
】无极【
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-5-14
收藏
得分:0 
空栈时 栈顶 ss:sp指向栈空间的最高地址单元的下一单元 (即最高地址+1)
老师说 栈空间大小和 栈顶是两个概念 ,但他们必须关联的啊?
2010-07-06 12:00
东海一鱼
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:48
帖 子:757
专家分:4760
注 册:2009-8-10
收藏
得分:0 
任何一种动态数据结构的管理都需要占用一些额外的空间,栈对象也不例外。所以我说不能只凭自己的想象,毕竟汇编需要很强的动手能力。我还是建议你自己用debug来跟踪一个现实的例子看看,才能明白真实的‘堆栈’长的是何种模样。

图片附件: 游客没有浏览图片的权限,请 登录注册

举世而誉之而不加劝,举世而非之而不加沮,定乎内外之分,辩乎荣辱之境,斯已矣。彼其于世未数数然也。
2010-07-07 08:59
快速回复:栈顶问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.021632 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved