C语言申请内存时堆栈大小限制
2016-10-18 11:11
246 查看
开辟一片内存空间有2种方式,第一种:int a[];第二种malloc,那么在Linux下,这两种方式可以开辟多大的内存空间呢?下面依次进行实验:
第一种方式:使用malloc申请内存;
这样的方式是在堆区申请的内存,在linux中,其实是在申请的时候基本没有限制,比如32位机器,理论上可以malloc(4G)的大小,因为2^32=4G,但事实上linux的进程地址空间是这样的:所以经过实验,使用malloc最大能够申请的空间是3G左右,这里要注意,要使用下面这样的方式申请空间:
[cpp] view
plain copy
int MB = 0;
while(malloc(1 << 20))
{
MB++;
}
printf("Allocate %d MB total\n", MB);
不能直接
[cpp] view
plain copy
size_t MB = (size_t)(2147483648UL);
char *buf = (char*)malloc(MB);
因为可能内存中存在碎片,内存空闲空间总和也许有3G,但是直接申请3G,可能会不成功,因为它不是连续的内存空间。
接下来我又迷茫了,为什么申请堆空间不受到swap空间和物理内存大小的限制呢?由于linux使用的是虚拟内存,因此分配是不受影响的,但是,在使用的时候,我们同时使用的内存大小超过了swap空间和物理内存大小,将会出现一些问题,这里有一篇文章说得不错,记录下:http://www.cfanz.cn/index.php?c=article&a=read&id=103888
第二种方式:使用int a[]申请内存;
这样的方式是在栈区申请的内存,在linux中,会受到ulimit -a中stack size结果的影响比如我的ulimit -a结果
[cpp] view
plain copy
stack size (kbytes, -s) 8192
那么代码中
[cpp] view
plain copy
// int MB[2097152]; 4*2097152 = 8192kb
int MB[2090000];
MB[0] = 0;
MB[2090000 - 1] = 0;
[cpp] view
plain copy
int MB[2097152];
使用int MB[2097152]会失败,因为堆栈可能保存参数,返回地址等等信息,已经占用了部分堆栈,下面的MB[2090000]是可以成功的!
所以总结一下:如果用malloc的方式,一个进程理论上是可以使用3G的内存(应该说可见),但是同时能够使用的真正最大内存只有swap空间+物理空间这么大
使用int a[]这样的形式,申请的空间会受到ulimit -a中stack size的影响。
ps:其实我觉得堆栈就不应该一起说~他俩的概念还是差很多的~我搜到的文章都把这两者混在一起说,非常容易迷惑人.....
记录下参考的文章:
http://www.cfanz.cn/index.PHP?c=article&a=read&id=103888
http://blog.csdn.NET/anghlq/article/details/7087069
http://tech.ddvip.com/2013-05/1369680397196183.html
http://www.jb51.net/LINUXjishu/34605.html
相关文章推荐
- 转:C语言申请内存时堆栈大小限制
- C语言申请内存时堆栈大小限制
- linux C语言 内存申请 堆 栈 大小限制
- C语言 全局变量和局部变量的大小限制(关于堆栈的划定)
- 栈(stack)上申请内存大小限制问题
- 使用dma_alloc_writecombine申请内存空间大小的限制
- C语言和C++中动态申请内存
- Linux零碎记录之ulimit【堆栈大小、stack size、进程数限制、文件句柄限制、linux用户空间限制】
- [转载] 数据结构在内存里的大小与对齐(C语言)
- java HashMap 极限容量 大小限制 占用内存大小
- C语言 全局变量和局部变量的大小限制
- sqlserver 限制内存大小
- C语言之struct大小、首地址与内存对齐—由结构体成员地址得到结构体首地址
- C语言之struct大小、首地址与内存对齐
- C语言用完申请来的内存怎么释放
- C语言之struct大小、首地址与内存对齐
- 局部堆栈大小有限制
- C语言 全局变量和局部变量的大小限制
- c语言中结构体的大小和内存对齐问题
- c#如何限制程序内存使用的大小