虚拟内存在内核层面算是一种中间层,为了适配不同的物理内存的管理和使用方式。
进程与内核的内存使用是通过虚拟内存管理提供的接口来实现的,虚拟内存的管理对进程是透明的。
虚拟内存不足,一方面可能是地址空间已经耗尽了,另一种可能是虚拟内存vm_struct_area已经不够了,也表明物理内存不足。
vm_struct_area对于开发的应用程序来说不可见。
内核维护了进程的私有信息,也就是task_struct,这个在开发的应用程序中是看不到这些信息,应该说task_struct才是开发中的进程的超类,在task_struct中维护了应用程序哪些所谓的进程信息,而task_struct的信息是由内核维护的,可认为task_struct中有指针指向了开发的应用程序,开发得到的应用程序只是内核装载进程时要填充的信息而已,如代码段,数据段,堆栈等。
内存泄露是指虚拟内存的泄露,本质上是只指进程占用的vm_struct_area,而这些资源都是内核的资源,当然还有其映射的物理内存,并没有释放还给内核,造成可用的系统资源越来越少了,直到进程崩溃,这些资源才会重新回收。
内存泄露的检查还是比较难的,进程的内存使用情况可以通过/proc/pid/maps看到一些信息,然而通过查看这些信息只能大概知道发生了内存泄露,并不能定位内存泄露,毕竟内存的泄露还是由于应用程序的使用不当导致,所以还是要在应用程序中去跟踪和查找。
对于一些预分配内存和内存池的应用程序,内存的泄露的可能性,还是比较小的。
阅读(5280) | 评论(1) | 转发(0) |