进程优化实验 node
Coding: shell
图1 Coding 数据结构
图2 shell输出 ide
图3 进程文件maps输出信息 函数
图4 cat smaps相关内存信息 优化
图5 cat statm相关信息显示 spa
分析: 进程
/proc 文件系统是一种内核和内核模块用来向进程发送信息的机制(因此叫/proc)。这个伪文件系统让你能够和内核内部数据结构进行交互,获取有关进程的有用信息,在运行中改变设置(经过改变内核参数)。与其余文件系统不一样,/proc 存在于内存之中而不是硬盘上。 内存
/proc 由内核控制,没有承载/proc的设备。由于/proc主要存放由控制的状态信息,因此大部分这些信息的逻辑位置位于内核控制的内存。对/proc进行一个 ‘ls -l’能够看到大部分文件都是0字节大的;可是查看这些文件的时候,确实能够看到一些信息。由于/proc文件系统和其余常规的文件系统同样把本身注册到虚拟文件系统层(VFS)了。然而,知道当VFS调用他,请求文件、目录的i-node的时候,/proc文件根据内核中的信息创建相应的文件和目录。 map
如图5所示,很简单地返回7组数字,每个单位都是一页也就是4KB
他们分别是:
Size:任务虚拟地址空间大小
Resident:应用程序正在使用的物理内存大小
Shared:共享页数
Trs:程序所拥有的可执行虚拟内存大小
Lrs:被映像到任务的虚拟内存空间的库的大小
Drs:程序数据段和用户态的栈的大小
dt: 脏页数量
如图1所示在char *p = (char *)malloc(20),只是分配了虚拟内存,内核不会分配物理页面给进程,在strcpy(p , “123”);进程须要使用这块内存了,内核会产生了一个页故障,从而为系统分配了一个物理页面。
如图3所示查看进程的maps文件能够看到进程的内存状况stack 也就是函数的栈大小系统固定的分配了84KB的大小,而堆大小132KB。在咱们的代码中只申请了20个字节,而系统却为其分配了132KB的虚拟内存。
(0Xbffd7000 – 0X00110000 ) / (1024)D / (1024)D / (1024)D = 2.998806 约等于 3G的大小。即Linux下执行一个小应用程序,系统就会自动给用户分配最低3G大小的虚拟空间。
每一个进程经过系统调用访问内核,Linux内核空间由系统内的全部进程共享。从进程的角度来看,每一个进程拥有4G的虚拟地址空间。其中0~3GB为各个进程的私有用户空间,这个空间对系统中的其余进程是可见的,最高的1G内核空间则为全部进程以及内核所共享。