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

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

以下是一种很可移植的方法,好像是哪个大牛写的,确实值得学习,函数调用函数,被调用的函数压栈肯定在调用者之后,因此记录:
#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 */
} 


阅读更多
文章标签: 编译器 null
个人分类: 其他
上一篇C++编程规范(一)组织和策略上的问题
下一篇C++编程规范(二)设计风格
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭