malloc一次性最大能申请多大内存空间 考虑32位linux情况的话,依据版本的话 如果是2.4版本之前的话,因为映射区是在1G地址位置,而且映射区与栈相对生长,malloc申请的空间大于128KB的话,调用的是mmap函数,因此分配的地址起始在1G位置,末端为3G,最大2G左右,所以一次最大申请为2G左右,如果小块小块累计申请的话算上堆区128M到1G区间的话,小块申请 malloc调用brk总和就0.9G,累计能申请到的为2.9G。 2.6到当前版本的话,因为映射区是在顶端靠近栈区,但是生长方向向下,与堆向上相对,一次malloc申请大空间,malloc调用mmap()能最大申请到2.9G左右,算上堆区128M开始向上小块累计的话,(因为2.9G被mmap了)累计就剩下零头,累计申请最大也是2.9G。 现在分配的才是虚拟地址(不是物理内存,即使物理内存才0.5G),只有真正使用的话,才会建立页表开始关联物理内存。 测试代码如下(Linux系统下,物理内存+交换内存>=4G情况下,得到2.8G左右,如果物理内存+交换内存 = N < 4GB, 得到的大概为(N – 0.2)G) #include<stdio.h> #include<stdlib.h> size_t maximum=0; int main(int argc,char *argv[]) { void * block; void * tmpblock; size_t blocksize[]={1024*1024, 1024, 1}; int i,count; for(i=0;i<3;i++){ for(count=1;;count++){ block = malloc(maximum+blocksize[i]*count); if(block){ tmpblock = block; maximum += blocksize[i]*count; free(block); }else{ break; } } } printf(“maximum malloc size = %lf GB ”,maximum*1.0 / 1024.0 / 1024.0 / 1024.0); printf(“the address is %x ”,tmpblock); printf(“the address end is %x ”, tmpblock + maximum); while(1); }
2024最新激活全家桶教程,稳定运行到2099年,请移步至置顶文章:https://sigusoft.com/99576.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。 文章由激活谷谷主-小谷整理,转载请注明出处:https://sigusoft.com/82802.html