判断栈的生长方向

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条回答
pangb
1楼-- · 2019-08-01 19:58
datasheet是王道啊
ousj
2楼-- · 2019-08-02 01:38
 精彩回答 2  元偷偷看……
morrisk
3楼-- · 2019-08-02 03:53
方法是对的。

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

对于x86平台的我用过的IDE,你的这个都是对的,但是x86的方向也是固定的啊。
kangzj
4楼-- · 2019-08-02 06:38
确实没什么实际意义,但却是一个面试题。考查分析问题的方法。
chenjunt
5楼-- · 2019-08-02 08:45
这个也是编译器依赖很强的
chuxh
6楼-- · 2019-08-02 10:11
对,换个编译器不知道还可以不。

一周热门 更多>