为什么我只能在具有16 GB RAM的计算机上分配2 GB?

时间:2012-10-20 14:52:17

标签: c linux malloc

  

可能重复:
  Can you allocate a very large single chunk of memory ( > 4GB ) in c or c++?

我在计算机上运行以下程序:

#include <stdio.h>
#include <stdlib.h>

#define ONE_GIGABYTE 1024*1024*1024


int main(void) {
    int ctr=0;

    for (;;) {
        char *ptr = (char*)malloc(ONE_GIGABYTE*sizeof(char));
        if (ptr == 0)
            return -1;

        ctr++;
        printf("%d\n", ctr);
    }
}

flyrev@stargazer:~/weirdstuff$ ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 128957
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 8192
cpu time               (seconds, -t) unlimited
max user processes              (-u) 128957
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited
flyrev@stargazer:~/weirdstuff$ free -g
             total       used       free     shared    buffers     cached
Mem:            15          6          8          0          0          4
-/+ buffers/cache:          2         13
Swap:            9          0          9
flyrev@stargazer:~/weirdstuff$ clang malloc-program.c 
flyrev@stargazer:~/weirdstuff$ ./a.out 
1
2
flyrev@stargazer:~/weirdstuff$ 

这里发生了什么?

2 个答案:

答案 0 :(得分:4)

你没有内存耗尽,你在32位系统上运行,因此地址空间不足,你可能会合理地期望能够在32位系统上分配4Gb,因为:

2^32 = 4Gb

但是,在大多数操作系统上,至少有50%的可用地址空间实际上是保留供内核使用的,因此你只能使用一半。

在Linux上,通过切换使用PAE kernel,可以在32位模式下使用超过4Gb。如果需要,许多Linux发行版都会提供PAE内核作为包。

编辑:正如Dietrich所说:PAE允许使用更多内存,但仍然只能提供4 GiB的地址空间。因此,对于16 GiB,您可以拥有8个程序,每个程序有2个GiB,但是您仍然不能拥有一个超过2-Gi的程序

答案 1 :(得分:1)

@Benj为这个问题提供了一个很好的答案。但是,我想补充一点,即使一个人正在使用64位系统,如果使用针对32位系统的编译器编译程序,他仍然可以只使用2GB的内存。

64位系统通常支持32位程序。但是32位系统无法运行64位系统。因此,如果作者选择,可以将不期望占用2GB内存的程序编译为目标32位系统。此外,即使在64位系统上,32位目标通常也是默认目标。