虚位以待(AD)
虚位以待(AD)
首页 > 软件编程 > C/C++编程 > C++解决大数组栈内存不够问题的方法分析

C++解决大数组栈内存不够问题的方法分析
类别:C/C++编程   作者:码皇   来源:互联网   点击:

这篇文章主要介绍了C++解决大数组栈内存不够问题的方法,结合实例形式对比分析了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;
    }

上面的几种方法中 ,使用动态分配数组内存,这样使用的时堆储存,还是比较好的方法,但是成本高;而使用添加static的方法成本最小。

希望本文所述对大家C++程序设计有所帮助。

您可能感兴趣的文章:

  • 浅谈C++内存分配及变长数组的动态分配
  • C/C++动态分配与释放内存的区别详细解析
  • C++内存泄漏及检测工具详解
  • 基于C++中常见内存错误的总结
  • C++程序检测内存泄漏的方法分享
  • C++中关于Crt的内存泄漏检测的分析介绍
  • 浅析C/C++变量在内存中的分布
  • C/C++ 传递动态内存的深入理解
  • C++动态内存分配(new/new[]和delete/delete[])详解
  • C++中字符串以及数组和指针的互相使用讲解
相关热词搜索: C++ 解决 大数组 栈内存 不够问题