今天在解决一道题的时候,在函数内部定义数组突然脑子抽风多打了几个零(一百万),一运行
——嗯,爆了orz
于是,我翻开了书,但并没有发现哪里有说数组大小限制。
后来找到度娘帮忙
-
首先明确,数组申明在函数内部,即属于局部变量,是存放在栈上的
-
其次,栈的默认内存空间为 1 M左右
-
一百万长度的数组占用的内存大小:1000000=1000 *1000 * 4byte ≈ 4M
int型数据长度为4byte
所以,会导致内存溢出。
要想解决这个问题有两种方法:可以将数组申明在全局存储区或堆上
方法一:申明为全局变量
#include<iostream>
using namespace std;
int list[1000000];
int main()
{
...
return 0;
}
方法二:存放在堆上
#include<iostream>
using namespace std;
int main()
{
int *list;
list=new int[1000000];
...
return 0;
}
总结一下:
- 函数内申请的变量,数组,是在栈(stack)中申请的一段连续的空间。栈的默认大小为2M或1M,开的比较小。
- 全局变量,全局数组,静态数组(static)则是开在全局区(静态区)(static)。大小为2G,所以能够开的很大。
- 而malloc、new出的空间,则是开在堆(heap)的一段不连续的空间。理论上则是硬盘大小。