如何判断一个栈的增长方向

一个很直观的做法就是说在一个函数中定义两个变量,把这两个变量的地址进行比较,但是这种方法是和编译器相关的,如果不同编译器对局部变量的压栈方式不一样,则无法判断,因此这种方法是不可移植的。  

以下是一种很可移植的方法,好像是哪个大牛写的,确实值得学习,函数调用函数,被调用的函数压栈肯定在调用者之后,因此记录:
#include<stdio.h> 
static void find_stack_direction(void); 
static int stack_dir; 
int main(void) { 
    find_stack_direction(); 
    if(stack_dir==1) puts("stack grew upward"); 
    else puts("stack grew downward"); 
    return 0; 
} 

static void find_stack_direction (void) {
    static char *addr = NULL; 
    /* address of first `dummy', once known */
    auto char dummy;
    /* to get stack address */
    if (addr == NULL) {
       /* initial entry */
        addr = &dummy;
        find_stack_direction (); /* recurse once */
    } else /* second entry */if (&dummy > addr) stack_dir = 1; /* stack grew upward */  
      else stack_dir = -1; /* stack grew downward */
} 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值