可能重复:
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$
这里发生了什么?
答案 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位目标通常也是默认目标。