一、栈和堆的区别。
1、申请方式的不同。栈由系统自动分配,堆由程序员使用new(关键字)或malloc(库函数)申请开辟;
2、申请大小的不同。栈获得的空间较小,windows系统里面栈的大小是2M,在linux系统里面栈的大小是8M,而堆获得的空间较大;
3、申请效率的不同。栈分配速度较快,但堆速度比较慢。因为系统用链表实现空闲地址空间的,所以堆的内存空间不连续的(链表的遍历效率低下)。
4、底层不同。栈是连续的空间,而堆是不连续的空间,容易产生内存碎片,不易管理,但使用方便。
二、栈溢出及解决方法。
栈溢出:
全局变量/局部静态变量存储于堆内存,堆区体积较大,一般不会溢出;
栈容量很小,一般也就一两兆,出现死循环或者大量的递归调用,很容易造成栈溢出。
栈溢出的解决方法:
①、谨慎使用递归调用。
②、函数传参对象为大型聚合对象,尽量使用引用或指针。
③、将减少栈空间的需求,堆空间分配内存。
例如:
栈溢出:
#include <iostream>
using namespace std;
int main()
{
//栈溢出示例:
const int nMax = 2 * 1024 * 512;
char arr[nMax] {};
cin.get();
return 0;
}
对象放在堆区就没问题:
#include <iostream>
using namespace std;
int main()
{
//栈非溢出示例:
const int nMax = 2 * 1024 * 512;
const char* p = new char[nMax];
delete[] p;
p = NULL;
cin.get();
return 0;
}