判断栈的生长方向

2019-08-01 16:23发布

我用以下方法判断栈的生长方向,各位看看有没有问题.
思想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
}

以上的方法只适合变量存在栈中的编译器
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
11条回答
llljh
2019-08-02 17:41
/*如果函数返回1为向上生长,-1向下生长*/
int FindStackDirection(void)
{
   static char *address = NULL;
   char dummy = 0;

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

一周热门 更多>