假设嵌入式linux目前可用的物理内存为5MB(5MB可用内存,并且没有可用的缓存或缓冲内存可用),如果我编写这段代码:
.....#define MEGABYTE 1024*1024..........voID *ptr = NulL;ptr = (voID *) malloc(6*MEGABYTE); //Preserving 6MBif (!prt) exit(1);memset(ptr,1,MEGABYTE);.....
我想知道,当提交memset调用时,内核将尝试在物理内存空间中分配~6MB或~1MB(或min_free_kbytes倍数).
现在我的嵌入式设备大约有9MB,有32MB RAM.我做了检查
# echo 3 > /proc/sys/vm/drop_caches # free total used free shared buffersMem: 23732 14184 9548 0 220Swap: 0 0 0Total: 23732 14184 9548
忘记最后一段C代码,我想知道当可用内存大约> 6MB时是否可能出现oom杀手.
我想知道当oom出现时系统是否内存不足,所以我认为我有两个选择:
>请参阅可疑进程的/ proc / pID / status中的VmRSS条目.
>设置/ proc / sys / vm / overcommit_memory = 2和/ proc / sys / vm / overcommit_memory = 75并查看是否有任何进程需要更多可用的物理内存.
以上是内存溢出为你收集整理的内存管理 – Linux内存过度使用细节全部内容,希望文章能够帮你解决内存管理 – Linux内存过度使用细节所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)