这篇文章主要介绍“C++中怎么解决大数组栈内存不够问题”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“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 <vector>
using namespace std;
void main()
{
vector<int> A(90000);
A[0] = 1;
}
关于“C++中怎么解决大数组栈内存不够问题”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注天达云行业资讯频道,小编每天都会为大家更新不同的知识点。