尽管有无限的ulimit,为什么非常大的堆栈分配会失败?

以下静态分配给出了分段错误
double U[100][2048][2048];

但是下面的动态分配很顺利

double ***U = (double ***)malloc(100 * sizeof(double **));

for(i=0;i<100;i++)
{
    U[i] = (double **)malloc(2048 * sizeof(double *));
    for(j=0;j<2048;j++)
    {
        U[i][j] = (double *)malloc(2048*sizeof(double));
    }
}

linux中的ulimit设置为无限制.

有人能给我一些暗示发生什么事吗?

解决方法

当你说ulimit设置为unlimited时,你使用-s选项吗?否则,这不会更改堆栈限制,只会更改文件大小限制.

但是,无论如何都会出现堆栈限制.我可以分配:

double *u = malloc(200*2048*2048*(sizeof(double)));  // 6gb contiguous memory

运行二进制文件我得到:

VmData:  6553660 kB

但是,如果我在堆栈上分配,它是:

double u[200][2048][2048];

VmStk:   2359308 kB

这显然不正确(暗示溢出).使用原始分配,两者给出相同的结果:

Array:  VmStk:   3276820 kB
malloc: VmData:  3276860 kB

但是,运行堆栈版本,无论数组的大小如何,我都无法生成错误 – 即使它超过系统上实际的总内存,如果设置了-s unlimited.

编辑:

我在循环中使用malloc进行了测试,直到失败:

VmData: 137435723384 kB  // my system doesn't quite have 131068gb RAM

但是,堆栈使用率从未达到4gb以上.

相关文章

在Linux上编写运行C语言程序,经常会遇到程序崩溃、卡死等异...
git使用小结很多人可能和我一样,起初对git是一无所知的。我...
1. 操作系统环境、安装包准备 宿主机:Max OSX 10.10.5 虚拟...
因为业务系统需求,需要对web服务作nginx代理,在不断的尝试...
Linux模块机制浅析 Linux允许用户通过插入模块,实现干预内核...
一、Hadoop HA的Web页面访问 Hadoop开启HA后,会同时存在两个...