C++中超大数组的空间分配

在C或者C++中,在函数(包括main函数)中定义数组,对于任何程序员来说都是so easy的事,当然这通常是对于一些容量小的数据;当我们有大量的数据需要处理的时候,比如1GB大小的数据,按照常规的方式在函数中定义数组空间,往往会运行出错,那么如何解决这样的问题呢?

在这里大家需要了解一点的是,C++中,在函数(包括main函数)中定义超大数组,内存为栈所分配的最大空间为4M,因此在子函数或者main函数中定义超大数组的方式是万万行不通的。

解决方式:为超大数组创建为一个全局数组。

有时候觉得数组使用起来不方便,可以采用定义vector的方式,但需要注意的是,vector通常只能分配出几百MB的空间。

vector  vec0;
vector  vec1;
vector  vec2;
vector  vec3;

cout<

在程序运行完之后得到的数据如下(win7系统  64位  VS2010下):

vec0 时为4294967295,即4G个元素

vec1 时为134217727,即128M个元素

vec2 时为1073741823,即1G个元素

vec3 时为536870911,即512M个元素

至于为何元素类型不同,返回的元素个数不同,我也不是很清楚,在这里给大家说一下。

此外,虽然上面显示了可以存放这么多数量的元素个数,但是一般情况下并不会真的让你存放这么多的数据。

由于vector在所需要的是一片连续的内存空间,有时候并不能实现,但是C++中 list 可以使用散列的空间,需要存放较大数据时可以使用 list 容器来存放数据。

 

 

 

你可能感兴趣的:(C++中超大数组的空间分配)