Android 内存分析

2018-10-23  本文已影响0人  gbmaotai

VSS

Vss是占用的虚拟内存,如果没有映射实际的内存也算进来。

RSS

Rss是占用的物理内存。是共享内存+私有内存。因为共享内存是多个进程共用的,所以存在重复计算。

PSS

Pss是占用的私有内存加上平分的共享内存。例如一块1M的共享内存被两个进程共享,那每个进程分500K。各进程的Pss相加基本等于实际被使用的物理内存,所以这个经常是最重要的参数。

USS

Uss Unique Set Size 进程独自占用的物理内存(不包含共享库占用的内存)USS 是一个非常非常有用的数字, 因为它揭示了运行一个特定进程的真实的内存增量大小。如果进程被终止, USS 就是实际被返还给系统的内存大小。
USS 是针对某个进程开始有可疑内存泄露的情况,进行检测的最佳数字。怀疑某个程序有内存泄露可以查看这个值是否一直有增加

procrank

 PID       Vss      Rss      Pss      Uss  cmdline
  818  1049892K  106988K   83446K   78648K  com.turingcat.controller
  513    93080K   39716K   34369K   29308K  mqttserver
 1143    77224K   38052K   32703K   27644K  homebridge
  466   942228K   45536K   23049K   19128K  system_server
  120   851284K   41196K   14829K    9060K  zygote
  737   927780K   33940K   12800K   10040K  com.android.settings
  599   899380K   33484K   12036K    9108K  com.android.systemui
  709   892220K   26440K    8658K    6852K  com.google.android.inputmethod.pinyin
  776   865424K   24504K    6919K    5324K  android.process.media
  758   864292K   23572K    6689K    5372K  android.process.acore
 1115   874688K   25848K    5768K    3680K  com.thirdparty.superuser:superuser
  962   869468K   22004K    5316K    4080K  com.android.bluetooth
  724   882820K   22316K    4813K    3404K  com.android.nfc
  122    29272K    7144K    4521K    3492K  /system/bin/mediaserver
 1069   873828K   22896K    4379K    2736K  com.thirdparty.superuser
 1024   863044K   20164K    4149K    2968K  com.android.gallery3d
 2545   862440K   20488K    4032K    2744K  com.android.inputmethod.latin
 1004   861292K   18424K    3058K    1904K  com.android.camera2
  789   860188K   18228K    2754K    1620K  com.android.provision
  875   860180K   18272K    2739K    1644K  com.android.externalstorage
  119    19584K    3668K    1767K    1424K  /system/bin/surfaceflinger
  121     9544K    3356K    1342K     796K  /system/bin/drmserver
  640     3368K    1932K    1055K     888K  /system/bin/wpa_supplicant
 3589     1792K    1268K    1046K    1040K  ./procrank
  116     9784K    1280K     605K     512K  /system/bin/netd
  114     4736K    1256K     588K     508K  /system/bin/vold
  124     3344K    1200K     454K     360K  /system/bin/keystore
  125     6632K     948K     441K     400K  /system/bin/ccd
    1      540K     368K     282K     220K  /init
  118     1368K     660K     241K     216K  /system/bin/rild
  918     1020K     540K     233K     220K  /system/bin/dhcpcd
 1422     7660K     236K     224K     224K  /sbin/adbd
  228     3504K     468K     192K     176K  /system/bin/sdcard
  854     3516K     464K     184K     168K  /system/bin/sdcard
  123      992K     484K     177K     164K  /system/bin/installd
 3571      928K     472K     156K     120K  sh
  117     1028K     408K     155K     144K  /system/bin/debuggerd
 3558      924K     468K     152K     116K  /system/bin/sh
   94      516K     216K     152K      92K  /sbin/ueventd
  240      924K     456K     148K     116K  /system/bin/sh
  112     1424K     144K     140K     140K  /sbin/healthd
  127      920K     444K     135K     104K  /system/bin/sh
 3565     2712K     192K     125K     104K  su
 1142      912K     432K     123K      92K  /system/bin/sh
  113      996K     324K     114K     108K  /system/bin/servicemanager
 3570      660K     128K      56K      32K  /system/xbin/su
 3568      660K     128K      53K      28K  /system/xbin/su
  115      656K     116K      45K      24K  /system/xbin/su
 3564      656K      96K      43K      28K  su
                           ------   ------  ------
                          287479K  237320K  TOTAL

RAM: 828508K total, 60664K free, 136668K buffers, 313116K cached, 900K shmem, 45636K slab

cat /proc/meminfo

可用内存=free的内存+cached的内存+buffers的内存

cat /proc/meminfo
cat /proc/meminfo
MemTotal:         828508 kB
MemFree:           68692 kB
Buffers:          136768 kB
Cached:           313116 kB
SwapCached:            0 kB
Active:           416584 kB
Inactive:         227840 kB
Active(anon):     195096 kB
Inactive(anon):      860 kB
Active(file):     221488 kB
Inactive(file):   226980 kB
Unevictable:         516 kB
Mlocked:               0 kB
HighTotal:             0 kB
HighFree:              0 kB
LowTotal:         828508 kB
LowFree:           68692 kB
SwapTotal:             0 kB
SwapFree:              0 kB
Dirty:                 0 kB
Writeback:             0 kB
AnonPages:        195292 kB
Mapped:            83904 kB
Shmem:               900 kB
Slab:              45740 kB
SReclaimable:      33352 kB
SUnreclaim:        12388 kB
KernelStack:        4296 kB
PageTables:         5604 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:      414252 kB
Committed_AS:   14549956 kB
VmallocTotal:    1021952 kB
VmallocUsed:       31488 kB
VmallocChunk:     719876 kB

dumpsys meminfo XXX

Android程序内存被分为2部分:native和dalvik,dalvik就是我们平常说的java堆,我们创建的对象是在这里面分配的,而bitmap是直接在native上分配的,对于内存的限制是 native+dalvik 不能超过最大限制。Android程序内存一般限制在16M。

Android应用程序的默认最大内存值

Android应用程序的默认最大内存值为16M,有些应用程序可能会出现内存溢出,譬如ERROR/AndroidRuntime(264):java.lang.OutOfMemoryError: bitmap size exceeds VM budget

修改配置文件

getprop  |grep heap
[dalvik.vm.heapgrowthlimit]: [192m]
[dalvik.vm.heapmaxfree]: [8m]
[dalvik.vm.heapminfree]: [512k]
[dalvik.vm.heapsize]: [512m]
[dalvik.vm.heapstartsize]: [16m]
[dalvik.vm.heaptargetutilization]: [0.75]
Applications Memory Usage (kB):
Uptime: 182335652 Realtime: 182335652

** MEMINFO in pid 818 [com.turingcat.controller] **
                   Pss  Private  Private  Swapped     Heap     Heap     Heap
                 Total    Dirty    Clean    Dirty     Size    Alloc     Free
                ------   ------   ------   ------   ------   ------   ------
  Native Heap    21827    21780        0        0    29232    27943     1156
  Dalvik Heap    24004    23892        0        0    51092    23684    27408
 Dalvik Other     9559     9404        0        0
        Stack      824      824        0        0
       Ashmem      132        0        0        0
    Other dev       21        0       20        0
     .so mmap     6254     2012     3184        0
    .apk mmap     1437        0      664        0
    .ttf mmap      506        0      180        0
    .dex mmap    18188     1056    15192        0
   Other mmap       94        4        8        0
      Unknown      348      348        0        0
        TOTAL    83194    59320    19248        0    80324    51627    28564

 Objects
               Views:      314         ViewRootImpl:        3
         AppContexts:       13           Activities:        3
              Assets:        2        AssetManagers:        2
       Local Binders:       42        Proxy Binders:       42
    Death Recipients:        1
     OpenSSL Sockets:        0

 SQL
         MEMORY_USED:     2956
  PAGECACHE_OVERFLOW:     2288          MALLOC_SIZE:       62

 DATABASES
      pgsz     dbsz   Lookaside(b)          cache  Dbname
         1     1088             21         0/37/3  /data/user/0/com.turingcat.controller/databases/ird.db
         4      196             21        0/147/3  /data/user/0/com.turingcat.controller/databases/vicenter.db
         4      296            457  155615/342/25  /data/user/0/com.turingcat.controller/databases/TuringCatProvider.db
         4       52            128      296/69/21  /data/user/0/com.turingcat.controller/databases/bugly_db_
         4       56             21         0/59/3  /data/user/0/com.turingcat.controller/databases/MideaSLK.db
         4     1560             87    32015/58/10  /data/user/0/com.turingcat.controller/databases/device_desc.db

showmap -a pid

更加细化

上一篇 下一篇

猜你喜欢

热点阅读