打印

如何判断栈的生长方向?

[复制链接]
3006|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
奇门遁甲|  楼主 | 2008-12-31 10:28 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
我用以下方法判断栈的生长方向,各位看看有没有问题.
思想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
}

以上的方法只适合变量存在栈中的编译器    


相关帖子

沙发
ayb_ice| | 2008-12-31 19:43 | 只看该作者

这个去看手册

使用特权

评论回复
板凳
红心j| | 2009-1-1 02:58 | 只看该作者

杞人忧天了,堆栈方向不是可变的

使用特权

评论回复
地板
linqing171| | 2009-1-2 10:26 | 只看该作者

应该是可行的

方法是对的。

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

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

使用特权

评论回复
5
奇门遁甲|  楼主 | 2009-1-2 12:24 | 只看该作者

re

确实没什么实际意义,但却是一个面试题。考查分析问题的方法。

使用特权

评论回复
6
hnrain| | 2009-1-2 15:54 | 只看该作者

恩。。。同意1!

讨论这个确实没意义。。!!
  但是如果光看思路的话,还是可以的!!

使用特权

评论回复
7
linqing171| | 2009-1-3 23:32 | 只看该作者

这个也是编译器依赖很强的

换个编译器不知道还可以不。
似乎C标准里面也没有规定编译器一定要做这么样。

使用特权

评论回复
8
340589344| | 2010-8-8 23:16 | 只看该作者
/*如果函数返回1为向上生长,-1向下生长*/
int FindStackDirection(void)
{
  static char *address = NULL;
  char dummy = 0;

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

使用特权

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

本版积分规则

5

主题

38

帖子

0

粉丝