我用以下方法判断栈的生长方向,各位看看有没有问题.
思想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
}
以上的方法只适合变量存在栈中的编译器
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
int FindStackDirection(void)
{
static char *address = NULL;
char dummy = 0;
if (NULL == address)
{
address = &dummy;
FindStackDirection();/*递归*/
}
else
{
return ((&dummy) > address) ? (1) : (-1);
}
}
一周热门 更多>