1. 在IDE中查看Log信息

当程序执行垃圾回收的时候,会打印一条Log信息。其格式例如以下:

D/dalvikvm: <GC_Reason> <Amount_freed>, <Heap_stats>, <External_memory_stats>, <Pause_time>



GC_Reason表示导致垃圾回收的原因以及当前的回收类型,包含下面几类:

    GC_CONCURRENT:当堆中对象数量达到一定是触发的垃圾收集

    GC_FOR_MALLOC:在内存已满的情况下分配内存,此时系统会暂停程序并回收内存

    GC_HPROF_DUMP_HEAP:创建FPFOR文件来分析Heap时所造成的垃圾收集

    GC_EXPLICIT: 程序调用了垃圾收集函数System.gc

GC_EXTERNAL_ALLOC: 出如今API 10及下面。为外部分配内存(native memory or NIO buffer)所造成的垃圾回收,高版本号所有分配在Dalvik Heap中。

Amount_freed 表示此次回收的内存



Heap_stats 表示空暇内存百分比和存活对象大小/堆的总大小



External_memory_stats 表示API 10及下面的外部分配内存。已分配内存/导致垃圾回收的界限



Pause_time 暂停时间。一个表示開始回收垃圾的时间。还有一个表示回收结束的暂停时间



D/dalvikvm( 9050): GC_CONCURRENT freed 2049K, 65% free 3571K/9991K, external 4703K/5261K, paused 2ms+2ms

注意这条信息中的 “ 3571K/9991K” 值,这代表着程序使用的heap大小。

2.使用DDMS

Eclipse中的DDMS提供了一个观察内存使用情况的GUI,当我们不断点击Cause GC时。就会看到当前程序的Heap,使用比較方便,详细使用方法能够Google一下。

3.使用adb dumpsys 命令

adb是一个很强大的工具,使用adb查看应用程序内存使用情况可按例如以下格式在命令行里查看内存使用情况:

adb shell dumpsys meminfo <package_name>

当中,package_name 也能够换成程序的pid。pid能够通过 adb shell top | grep app_name 来查找,下图是某个程序的内存使用情况:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmlnY29udmllbmNl/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

重点关注例如以下几个字段:

(1) Native/Dalvik 的 Heap 信息

详细在上面的第一行和第二行,它分别给出的是JNI层和Java层的内存分配情况,假设发现这个值一直增长,则代表程序可能出现了内存泄漏。



(2) Total 的 PSS 信息

这个值就是你的应用真正占领的内存大小,通过这个信息。你能够轻松判别手机中哪些程序占内存比較大了。

4. 使用adb shell procrank

手机中的sh是经过精简过的。有些手机可能没有 procrank 命令。能够使用genymotion模拟器。或是自己安装procrank命令。使用procrank时,命令行的输出入下图:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYmlnY29udmllbmNl/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

能够看到,在linux下表示内存的耗用情况有四种不同的表现形式:

 VSS - Virtual Set Size 虚拟耗用内存(包括共享库占用的内存)

 RSS - Resident Set Size 实际使用物理内存(包括共享库占用的内存)

 PSS - Proportional Set Size 实际使用的物理内存(比例分配共享库占用的内存)

 USS - Unique Set Size 进程独自占用的物理内存(不包括共享库占用的内存)

VSS:VSS表示一个进程可訪问的所有内存地址空间的大小。

这个大小包含了进程已经申请但尚未使用的内存空间。在实际中非常少用这样的方式来表示进程占用内存的情况,用它来表示单个进程的内存使用情况是不准确的。

RSS:表示一个进程在RAM中实际使用的空间地址大小。包含了所有共享库占用的内存。这样的表示进程占用内存的情况也是不准确的。

PSS:表示一个进程在RAM中实际使用的空间地址大小,它按比例包括了共享库占用的内存。假如有3个进程使用同一个共享库,那么每一个进程的PSS就包括了1/3大小的共享库内存。

这样的方式表示进程的内存使用情况较准确。但当仅仅有一个进程使用共享库时,其情况和RSS一模一样。

USS:表示一个进程本身占用的内存空间大小,不包括其他不论什么成分,这是表示进程内存大小的最好方式!

能够看到:VSS>=RSS>=PSS>=USS

5.其他经常使用命令命令:

adb shell kill PIDNumber  死你想杀死的后台进程来模拟某种 bug 的复现条件。

adb shell ps  查看当前终端中的进程信息



那么怎样在代码中推断当前的硬件系统有多少的 RAM 呢?在 Framework  ProcessList.java 中有例如以下代码可用:

ProcessList() {  

   MemInfoReader minfo = new MemInfoReader();  

   minfo.readMemInfo();  

   mTotalMemMb = minfo.getTotalSize()/(1024*1024);  

}  



查看进程占用cpu的情况:adb shell top -n 1 -d 0.5 | grep proc_ id

Android 中查看内存的使用情况集经常使用adb命令的更多相关文章

  1. Android 中查看内存的使用情况集常用adb命令

    http://blog.csdn.net/bigconvience/article/details/35553983 http://blog.csdn.net/duantihi/article/det ...

  2. Android内存管理(7)在AS中查看内存和cpu情况

    Memory and CPU monitor Android Studio provides a memory and CPU monitor view so you can more easily ...

  3. 查找并修复Android中的内存泄露—OutOfMemoryError

    [编者按]本文作者为来自南非约翰内斯堡的女程序员 Rebecca Franks,Rebecca 热衷于安卓开发,拥有4年安卓应用开发经验.有点完美主义者,喜爱美食. 本文系国内ITOM管理平台 One ...

  4. 萌新笔记——linux下查看内存的使用情况

    windows上有各种软件可以进行"一键加速"之类的操作,释放掉一些内存(虽然我暂时不知道是怎么办到的,有待后续学习).而任务管理器也可以很方便地查看各进程使用的内存情况,如下图: ...

  5. 系统剖析Android中的内存泄漏

    [转发]作为Android开发人员,我们或多或少都听说过内存泄漏.那么何为内存泄漏,Android中的内存泄漏又是什么样子的呢,本文将简单概括的进行一些总结. 关于内存泄露的定义,我可以理解成这样 没 ...

  6. linux下查看内存的使用情况

    windows上有各种软件可以进行“一键加速”之类的操作,释放掉一些内存(虽然我暂时不知道是怎么办到的,有待后续学习).而任务管理器也可以很方便地查看各进程使用的内存情况,如下图: 同样地,linux ...

  7. Android中的内存管理机制以及正确的使用方式

    概述 从操作系统的角度来说,内存就是一块数据存储区域,属于可被操作系统调度的资源.现代多任务(进程)的操作系统中,内存管理尤为重要,操作系统需要为每一个进程合理的分配内存资源,所以可以从两方面来理解操 ...

  8. 在一个shell中查看管理 任务(前台和后台)/工作jobs 的命令

    在一个shell中查看管理 任务(前台和后台)/工作jobs 的命令 jobs是在同一个shell环境而言, 才有意义的. 为什么有jobs这个命令? 是因为, 如果从cmd line运行gui程序时 ...

  9. 【转】Android中的内存管理--不错不错,避免使用枚举类型

    原文网址:http://android-performance.com/android/2014/02/17/android-manage-memory.html 本文内容翻译自:http://dev ...

随机推荐

  1. H5 manifest离线缓存

    请跳转我的有道云笔记查看: http://note.youdao.com/noteshare?id=caaf067c6e38820ba8f87b212c2327a9&sub=23E0F8F7A ...

  2. mysql将字符串字段转为数字排序或比大小

    SELECT * FROM Student WHERE 1 = 1 ORDER BY -ID DESC ; SELECT * FROM Student WHERE 1 = 1 ORDER BY (ID ...

  3. mysql: Error Codes and Messages

    Appendix B. Error Codes and MessagesTable of Contents B.1. Server Error Codes and MessagesB.2. Clien ...

  4. 白话空间统计之:Moran&#39;s I(莫兰指数)

    前两天聊了空间统计学里面的两个经典概念,今天来说说第一篇文章留下的大坑:Moran's I. 首先,Moran's I这个东西.官方叫做:莫兰指数,是澳大利亚统计学家帕特里克·阿尔弗雷德·皮尔斯·莫兰 ...

  5. centos使用密钥替换密码登录服务器

    一.首先登陆centos,切换用户,切换到你要免密码登陆的用户,进入到家目录,以下我以admin为例,命令:su admincd ~ 二.创建钥匙,命令:ssh-keygen -t rsa,一路按Y搞 ...

  6. "com.android.ide.s.ProcessException:Process 'cand 'C:\Program Files\Java\jdk1.8.0_60\bin\java.exe'' finished with non-zero exit value 2"

    使用Android Studio 出现该问题: "com.android.ide.common.process.ProcessException: org.gradle.process.in ...

  7. Firefox的缓存问题

    使用Firefox调试代码时,JS或CSS文件修改后,怎么刷新都不生效.原来是Firefox缓存的问题.但Firefox没有像IE一样有个每次读取最新的设置. 设置Firefox不缓存页面: 新建标签 ...

  8. 《深入理解Java虚拟机》笔记6

    class文件由无符号数和表两种类型数据构成.表其实相当于一种结构体,内部又嵌套无符号数或者表. 用u1,u2,u4,u8分别代表一个字节,两个字节,四个字节,八个字节的无符号数. 如图中所示,cla ...

  9. Mac 快捷键整理(不定期更新)

    刚用Mac, 感到有点困难,记录几个快捷键: 1) 在全屏间切换: ctrl + command + F 2)向后删: Fn + delete

  10. Linux C高级编程——网络编程之以太网(2)

    Linux网络编程--以太网 宗旨:技术的学习是有限的,分享的精神是无限的. 1.以太网帧格式 源地址和目的地址是指网卡的硬件地址(也叫MAC地址),长度是48位,是在网卡出厂时固化的.用ifconf ...