判断栈的生长方向

[复制链接]
1053|11
 楼主| yinxiangh 发表于 2014-6-23 20:18 | 显示全部楼层 |阅读模式
TEST, TE, ST, IDT, AI
我用以下方法判断栈的生长方向,各位看看有没有问题.
思想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
}

以上的方法只适合变量存在栈中的编译器
pangb 发表于 2014-6-23 20:19 | 显示全部楼层
datasheet是王道啊
ousj 发表于 2014-6-23 20:20 | 显示全部楼层
杞人忧天了,堆栈方向不是可变的
morrisk 发表于 2014-6-23 20:20 | 显示全部楼层
方法是对的。

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

对于x86平台的我用过的IDE,你的这个都是对的,但是x86的方向也是固定的啊。
kangzj 发表于 2014-6-23 20:21 | 显示全部楼层
确实没什么实际意义,但却是一个面试题。考查分析问题的方法。
chenjunt 发表于 2014-6-23 20:21 | 显示全部楼层
这个也是编译器依赖很强的
chuxh 发表于 2014-6-23 20:22 | 显示全部楼层
对,换个编译器不知道还可以不。
juventus9554 发表于 2014-6-23 20:23 | 显示全部楼层
似乎C标准里面也没有规定编译器一定要做这么样。
llljh 发表于 2014-6-23 20:24 | 显示全部楼层
/*如果函数返回1为向上生长,-1向下生长*/
int FindStackDirection(void)
{
   static char *address = NULL;
   char dummy = 0;

  if (NULL == address)
   {        
       address = &dummy;
       FindStackDirection();/*递归*/
    }
   else
   {
           return ((&dummy) > address) ? (1) : (-1);
   }
}
 楼主| yinxiangh 发表于 2014-6-23 20:26 | 显示全部楼层
我在捉摸琢磨吧,多谢了
 楼主| yinxiangh 发表于 2014-6-23 20:26 | 显示全部楼层
先结贴了
comeon201208 发表于 2014-6-23 21:09 | 显示全部楼层
这个看来我不是很理解的啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则

723

主题

7134

帖子

2

粉丝
快速回复 在线客服 返回列表 返回顶部