了解Linux / proc / id / maps
我试图了解嵌入式Linux应用程序的内存使用情况。该/proc/pid/maps
实用程序/文件似乎是查看详细信息的好资源。不幸的是,我不理解所有的列和条目。
匿名索引节点0条目是什么意思?这些似乎是一些较大的内存段。
回答:
中的每一行都/proc/$PID/maps
描述了进程或线程中连续虚拟内存的区域。每行都有以下字段:
address perms offset dev inode pathname08048000-08056000 r-xp 00000000 03:0c 64593 /usr/sbin/gpm
- -这是进程地址空间中区域的开始和结束地址
- -描述如何访问区域中的页面。有四种不同的权限:读取,写入,执行和共享。如果禁用了读/写/执行,
-
将显示a而不是r
/w
/x
。如果区域不 共享的 ,它是 私人 ,所以p
会出现,而不是一个s
。如果该进程尝试以不允许的方式访问内存,则会产生分段错误。可以使用mprotect
系统调用来更改权限。 - 如果是从文件映射区域(使用
mmap
),则这是映射开始的文件中的偏移量。如果内存不是从文件映射的,则仅为0。 - -如果该区域是从文件映射的,则这是文件所在的主要和次要设备编号(十六进制)。
- -如果该区域是从文件映射的,则为文件号。
- 如果区域是从文件映射的,则这是文件的名称。对于匿名映射区域,此字段为空白。此外还有一些与名特殊地区,如
[heap]
,[stack]
或[vdso]
。[vdso]
代表虚拟动态共享对象。系统调用使用它来切换到内核模式。您可能会注意到很多匿名区域。这些通常由
mmap
但不附加到任何文件创建。它们用于许多其他事情,例如共享内存或未在堆上分配的缓冲区。例如,我认为pthread库使用匿名映射的区域作为新线程的堆栈。
以上是 了解Linux / proc / id / maps 的全部内容, 来源链接: utcz.com/qa/409358.html