时间:2021-05-20
本文实例讲述了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;}上面的几种方法中 ,使用动态分配数组内存,这样使用的时堆储存,还是比较好的方法,但是成本高;而使用添加static的方法成本最小。
希望本文所述对大家C++程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1、引入inline关键字的原因在c/c++中,为了解决一些频繁调用的小函数大量消耗栈空间(栈内存)的问题,特别的引入了inline修饰符,表示为内联函数。栈空
1.引入inline关键字的原因在c/c++中,为了解决一些频繁调用的小函数大量消耗栈空间(栈内存)的问题,特别的引入了inline修饰符,表示为内联函数。栈空
了解动态内存在C++中是如何工作的是成为一名合格的C++程序员必不可少的。C++程序中的内存分为两个部分:栈:在函数内部声明的所有变量都将占用栈内存。堆:这是程
C/C++中堆和栈及静态数据区详解 五大内存分区 在C++中,内存分成5个区,他们分别是堆、栈、自由存储区、全局/静态存储区和常量存储区。下面分别来介绍:
一.内存溢出解决方案在做数据统计分析时,经常会遇到大数组,可能会发生内存溢出,这里分享一下我的解决方案。还是用例子来说明这个问题,如下:假定日志中存放的记录数为