C++中如何解决大数组栈内存不够问题

这篇文章给大家分享的是有关C++中如何解决大数组栈内存不够问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

成都创新互联公司专注于企业成都营销网站建设、网站重做改版、洪泽网站定制设计、自适应品牌网站建设、H5开发商城网站定制开发、集团公司官网建设、成都外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为洪泽等各大城市提供网站开发制作服务。

本文实例讲述了C++解决大数组栈内存不够问题的方法。分享给大家供大家参考,具体如下:

在c++中,我们可以直接通过下面的方式创建一个数组:

const int N = 6;
const int Nx = 100;
const int Ny = 100;
double phi[N][Nx][Ny];
double phi_b[N][Nx][Ny];

但是,如果上述的Nx和Ny比较小还好说,一旦Nx和Ny很大时,就会报错,导致编译失败。

为解决这一问题,我们可以采用下面的几种方法来解决此问题:

1、在VC的Project setting里的link选项卡里把栈开大一点(windows里默认是4M)

2、声明成全局或static的,这两种变量不压栈,想开多大都可以,显然全局的变量其本身就可以拥有更多的内存   (这个方法可以立即奏效,还是不错的)

3、使用动态分配数组内存的方法:

int *A = new int[90000];
.....
delete A;

4、使用vector,如下:

#include 
using namespace std;
void main()
{
  vector A(90000);
  A[0] = 1;
}

感谢各位的阅读!关于“C++中如何解决大数组栈内存不够问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!


标题名称:C++中如何解决大数组栈内存不够问题
网站链接:http://myzitong.com/article/jhhsph.html