关于VSS / RSS / PSS / USS的解释是否准确?

时间:2014-03-13 08:28:56

标签: android memory-management

我读了关于VSS / RSS / PSS / USS的解释:


这篇文章的目的是提供有助于从各种工具解释内存报告的信息,以便确定Linux进程和系统的真实内存使用情况。

Android有一个名为procrank(/ system / xbin / procrank)的工具,它按从高到低的顺序列出了Linux进程的内存使用情况。每个过程报告的大小为VSS,RSS,PSS和USS。

为了简化本说明书,存储器将以页面而不是字节表示。像我们这样的Linux系统在最低级别管理4096字节页面的内存。

VSS(从ps报告为VSZ)是进程的总可访问地址空间。此大小还包括可能不驻留在RAM中的内存,如已分配但未写入的malloc。 VSS很难用于确定进程的实际内存使用情况。

RSS是进程中实际保存在RAM中的总内存。 RSS可能会产生误导,因为它报告了该进程使用的所有共享库的总数,即使共享库仅加载到内存中一次,无论有多少进程使用它。 RSS不能准确表示单个进程的内存使用情况。

PSS与RSS的不同之处在于它报告了其共享库的比例大小,即如果三个进程都使用具有30个页面的共享库,则该库将仅为每个报告的PSS贡献10个页面。三个过程。 PSS是一个非常有用的数字,因为当系统中所有进程的PSS相加时,这是系统中总内存使用量的良好表示。当进程被终止时,为其PSS贡献的共享库将按比例分配给仍在使用该库的其余进程的PSS总计。这样,PSS可能会产生一些误导,因为当一个进程被终止时,PSS无法准确地表示返回整个系统的内存。

USS是进程的总私有内存,即该进程完全唯一的内存。 USS是一个非常有用的数字,因为它表示运行特定进程的真正增量成本。当进程被终止时,USS是实际返回给系统的总内存。当最初怀疑某个过程中的内存泄漏时,USS是最好的数字。

对于有Python可用的系统,还有一个很好的工具叫做smem,它会报告内存统计信息,包括所有这些类别。

# procrank
procrank
PID      Vss        Rss           Pss         Uss   cmdline
481   31536K   30936K   14337K    9956K  system_server
475   26128K   26128K   10046K    5992K  zygote
526   25108K   25108K    9225K    5384K  android.process.acore
523   22388K   22388K    7166K    3432K  com.android.phone
574   21632K   21632K    6109K    2468K  com.android.settings
521   20816K   20816K    6050K    2776K  jp.co.omronsoft.openwnn
474    3304K    3304K    1097K     624K   /system/bin/mediaserver
37     304K      304K     289K      288K  /sbin/adbd
29     720K      720K     261K      212K  /system/bin/rild
601     412K     412K     225K      216K  procrank
   1     204K     204K     185K      184K  /init
35     388K     388K     182K      172K  /system/bin/qemud
284     384K     384K     160K      148K  top
27     376K     376K     148K      136K  /system/bin/vold
261     332K     332K     123K     112K  logcat
33     396K     396K     105K       80K   /system/bin/keystore
32     316K     316K     100K       88K   /system/bin/installd
269     328K     328K      95K       72K  /system/bin/sh
26     280K     280K      93K       84K   /system/bin/servicemanager
45     304K     304K      91K       80K   /system/bin/qemu-props
34     324K     324K      91K       68K   /system/bin/sh
260     324K     324K      91K       68K   /system/bin/sh
600     324K     324K      91K      68K   /system/bin/sh
25     308K     308K      88K       68K   /system/bin/sh
28     232K     232K      67K       60K   /system/bin/debuggerd
#

但是我找不到这篇文章的原文,我想知道这个解释是否准确。

1 个答案:

答案 0 :(得分:21)

这听起来是正确的,也与这里的描述对齐:http://elinux.org/Android_Memory_Usage

从页面...

  • Vss =虚拟集大小
  • Rss =常驻集大小
  • Pss =比例集大小
  • Uss =唯一设置尺寸