测试堆和栈的开口方向

   我们知道程序是在内存中运行的,内存可以分为四个分区,如果不清楚可以参考文章《运行程序内存分析(c语言)》

https://blog.csdn.net/suoyudong/article/details/79946689

我们今天来探讨的是测试堆,以及栈的开口方向。一般来说,栈的开口方向是向下的,堆的开口方向是向上的。

测试堆和栈的开口方向

测试方法:栈测试。局部变量在操作系统分配内存是栈操作,我们可以定义两个局部变量,打印其地址。例如如果先定义a,后定义b,a的地址大于b的地址,说明开口向下,反之则开口向上。

测试堆和栈的开口方向

测试代码:

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
//栈的开口向上向下,测试release和debug
//一般认为,栈的开口是向下的,这样可以防止栈的溢出
//不管栈开口向上还是向下,buf的内存地址buf+1,永远向上的
int main()//测试栈的开口方向
{
int a;
int b;//局部变量在操作系统分配内存是栈操作。
printf("&a:%p,&b:%p\n", &a, &b);
//结果是:&a:0078FDB0,&b:0078FDA4
//说明b的地址小,开口向下。
return 0;
}

堆测试,原理和栈相同。可以malloc两个堆,然后看其地址。

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
//验证堆的开口方向
int main()
{
int *p1 = NULL;
int *p2 = NULL;
p1 = (int*)malloc(10);
p2 = (int*)malloc(10);
printf("p1:%p,p2:%p\n", p1, p2);
if (p1 == NULL)
{
free(p1);
}
if (p2 == NULL)
{
free(p2);
}
return 0;
}
//结果是p1:02AC5750,p2:02AC5788
//p1>p2,说明heap区的开口也是向下的。