关于堆栈的问题:在c语言中,由于把a变量压入堆栈,top弹出堆栈的时候,弹出来的值是给谁

如果这个值不是返回给a的话,那堆栈的意义在哪里?请高手解释下

1. 首先一点你要明白的是,栈中保存的是值,也就是a入栈,是把a的值放到栈中,栈不会记得这个值是a的。

2. C语言中,我们使用栈从来都只是为了保存一个值而已,并不关心这个值是谁的。你想想看,你使用栈的过程中有去关心过每个入栈的值的来源吗?栈只是简单的数据堆放的仓库而已,不过是进进出出要按照顺序罢了。

3. 栈弹出时,弹出一个值,这个值要赋给谁,由你自己决定,但是他绝对不会自动赋给a。你可以仍旧赋给a,或者赋给b,c,d等等,比如像 函数Pop(Stack s, int a)中a就是你自己指定了。

4. 弹出栈的时候,要注意的一点是,你要想把原来压入栈中的值重新赋回给a,那么很重要的一点是,你要确定这个弹出的值确实是a的,这就要求你要记住入栈,出栈的顺序。这个你应该知道吧。

5. 上面说的几点都是我从要想要得到的答案方面回答的,但实际中要要保存a的值,肯定是在声明一个变量保存,int b = a; 不就可以了。不会有人真的去构造一个栈来保存值。真正需要用栈来保存值是在汇编语言中(不知道你学过没有),寄存器只有有限的10几个,只能靠栈来保存一些值,不像C中变量可以声明无数个,可能说过头了,希望你可以明白。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-12-23
没明白你的意思,首先你要明白堆中的空间并不像栈是有秩序的.堆是一大堆不连续的空间,所以根本不存在压不压入堆的说法.还有,堆栈不能连续说,堆就是堆,栈就是栈.堆栈是两者的总称.
相似回答