一个很直观的做法就是说在一个函数中定义两个变量,把这两个变量的地址进行比较,但是这种方法是和编译器相关的,如果不同编译器对局部变量的压栈方式不一样,则无法判断,因此这种方法是不可移植的。
以下是一种很可移植的方法,好像是哪个大牛写的,确实值得学习,函数调用函数,被调用的函数压栈肯定在调用者之后,因此记录:
#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 */
}