打印

栈的生长方向

[复制链接]
1254|13
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
yinxiangh|  楼主 | 2014-1-28 18:05 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我用以下方法判断栈的生长方向,各位看看有没有问题.
思想test()中调用test_2(),因此,test()中的变量必先进栈;

void test();
void test_2();
int * t;
int * k;
int main(void)
{
test();
if (t<k){
printf("stack grow up");
}else{
printf)"stack grow down");
}
return (1);
}
void test();
{
int t_test=1;
t=(int *)&t_test; //保存t_test地址到t
test_2();
}
void test_2()
{
int k_test=1;
k=(int *)&k_test; //保存k_test地址 到k
}

以上的方法只适合变量存在栈中的编译器
沙发
supernan| | 2014-1-28 18:06 | 只看该作者
datasheet是王道啊

使用特权

评论回复
板凳
pangb| | 2014-1-28 18:07 | 只看该作者
杞人忧天了,堆栈方向不是可变的

使用特权

评论回复
地板
chenjunt| | 2014-1-28 18:07 | 只看该作者
方法是对的。

但是不要试图在pic16f877中使用,因为他没有堆栈,而且堆栈不可访问,变量是编译器直接分配的RAM。

对于x86平台的我用过的IDE,你的这个都是对的,但是x86的方向也是固定的啊。

使用特权

评论回复
5
ousj| | 2014-1-28 18:08 | 只看该作者
确实没什么实际意义,但却是一个面试题。考查分析问题的方法。

使用特权

评论回复
6
morrisk| | 2014-1-28 18:09 | 只看该作者
这个也是编译器依赖很强的

使用特权

评论回复
7
小小猫咪| | 2014-1-28 18:10 | 只看该作者
对,换个编译器不知道还可以不。

使用特权

评论回复
8
kangzj| | 2014-1-28 18:10 | 只看该作者
似乎C标准里面也没有规定编译器一定要做这么样。

使用特权

评论回复
9
houcs| | 2014-1-28 18:12 | 只看该作者
/*如果函数返回1为向上生长,-1向下生长*/
int FindStackDirection(void)
{
    static char *address = NULL;
    char dummy = 0;

   if (NULL == address)
    {        
        address = &dummy;
        FindStackDirection();/*递归*/
     }
    else
    {
            return ((&dummy) > address) ? (1) : (-1);
    }
}

使用特权

评论回复
10
liuzaiy| | 2014-1-28 18:13 | 只看该作者
参数 是压栈的 (不inline优化的话) ,变量可能在堆栈,可能在寄存器里,甚至被优化掉。

使用特权

评论回复
11
houcs| | 2014-1-28 18:14 | 只看该作者
和平台有关吧

使用特权

评论回复
12
zwll| | 2014-1-28 18:14 | 只看该作者
以上的方法只适合变量存在栈中的编译器
为什么不在寄存器中,优化后大多应该在寄存器中

使用特权

评论回复
13
yinxiangh|  楼主 | 2014-1-28 18:16 | 只看该作者
知道了

使用特权

评论回复
14
yinxiangh|  楼主 | 2014-1-28 18:17 | 只看该作者
先结贴了,多谢大家哈~~~

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

723

主题

7134

帖子

2

粉丝