专栏名称: 安卓开发精选
伯乐在线旗下账号,分享安卓应用相关内容,包括:安卓应用开发、设计和动态等。
目录
相关文章推荐
郭霖  ·  iPhone 到 Android ... ·  4 天前  
郭霖  ·  Android Surface截图方法总结 ·  6 天前  
stormzhang  ·  又被平均了? ·  3 天前  
鸿洋  ·  一文搞懂Window、PhoneWindow ... ·  1 周前  
51好读  ›  专栏  ›  安卓开发精选

dumpsys 命令用法

安卓开发精选  · 公众号  · android  · 2016-09-30 09:47

正文

(点击上方公众号,可快速关注)


来源:伯乐在线专栏作者 - gityuan

链接:http://android.jobbole.com/84818/

点击 → 了解如何加入专栏作者


dumpsys命令功能很强大,能dump系统服务的各种状态,非常有必要熟悉该命令的用法以及含义。


一、 dumpsys命令


1.1 服务列表


不同的Android系统版本支持的命令有所不同,可通过下面命令查看当前手机所支持的dump服务,先进入adb shell,再执行如下命令:dumpsys -l。 这些服务名或许你并看不出其调用的哪个服务,那么这时可以通过下面指令:service list。


表一:


服务名类名功能
activityActivityManagerServiceAMS相关信息
packagePackageManagerServicePMS相关信息
windowWindowManagerServiceWMS相关信息
inputInputManagerServiceIMS相关信息
powerPowerManagerServicePMS相关信息
batterystatsBatterystatsService电池统计信息
batteryBatteryService电池信息
alarmAlarmManagerService闹钟信息
dropboxDropboxManagerService调试相关
procstatsProcessStatsService进程统计
cpuinfoCpuBinderCPU
meminfoMemBinder内存
gfxinfoGraphicsBinder图像
dbinfoDbBinder数据库


表二:


服务名功能
SurfaceFlinger图像相关
appopsapp使用情况
permission权限
processinfo进程服务
batteryproperties电池相关
audio查看声音信息
netstats查看网络统计信息
diskstats查看空间free状态
jobscheduler查看任务计划
wifiwifi信息
diskstats磁盘情况
usagestats用户使用情况
devicestoragemonitor设备信息
。。。。。。


未完待续…


1.2 查询服务


通过下面命令可打印具体某一项服务:dumpsys ,其中便是前面表格中的服务名,比如:


dumpsys cpuinfo //打印一段时间进程的CPU使用百分比排行榜

dumpsys meminfo -h  //查看dump内存的帮助信息

dumpsys package //查看指定包的信息


系统服务非常之多,那么接下来将重点说说其中之一:dumpsys activity用法.


二、 Activity


dumpsys activity [options] [cmd]


下面分别说说options和cmd有哪些可选值


2.1 options


options可选值:


  • -a:dump所有;

  • -c:dump客户端;

  • -p [package]:dump指定的包名;

  • -h:输出帮助信息;


dumpsys activity等价于依次输出下面7条指令:


dumpsys activity intents

dumpsys activity broadcasts

dumpsys activity providers

dumpsys activity services

dumpsys activity recents

dumpsys activity activities

dumpsys activity processes


2.2 cmd


cmd可选值


cmd解释缩写
activitiesactivity状态a
broadcasts广播b
intentspending intent状态i
processes进程p
oom内存溢出o
servicesService状态s
serviceservice状态(Client端)
providersContentProvider状态prov
providerContentProvider状态(Client端)
associationstracked app associationsas
permissionsURI permission grant stateperm
packagepackage相关信息
all所有的activities信息
recentsrecent activity状态r
toptop activity信息
write将状态持久化到存储区
track-associations使能association tracking
untrack-associations禁止和清空association tracking


  • cmd:上表加粗项是指直接跟包名,另外services和providers还可以跟组件名;

  • 缩写:基本都是cmd首字母或者前几个字母,用cmd和缩写是等效: dumpsys activity broadcasts dumpsys activity b //等效


三、场景


下面以新浪微博App作为实例,由于输出结果较多,每个场景截图只挑选部分重要的信息。


场景1:查询某个App所有的Service状态


dumpsys activity s com.sina.weibo



解读:


  • Service类名为com.morgoo.droidplugin.PluginManagerService;

  • 运行在进程pid=7220,进程名为com.sina.weibo,uid=10094;

  • 通过bindService连接该服务的进程pid=7306,进程名为com.sina.weibo:PluginP03。


当然还有packageName,baseDir(apk路径),dataDir(apk数据路径),createTime等各种信息。另外,新浪微博采用的是360开源的Android插件机制(com.morgoo.droidplugin),主要用于hotfix等功能。


场景2:查询某个App所有的广播状态


dumpsys activity s com.sina.weibo



解读:


  • android.intent.action.SCREEN_ON代表手机亮屏广播;

  • 接收该广播的receiver有很多个,其中一个所在进程为pid=7220,进程名为com.sina.weibo


场景3:查询某个App所有的Activity状态


输出结果较多,尤其是View Hierarchy,下面截取部分:


dumpsys activity a com.sina.weibo



解读:


  • 格式:TaskRecord{Hashcode #TaskId Affinity UserId=0 Activity个数=1};所以上图信息解析后就是TaskId=1802,Affinity=com.sina.weibo,当前Task中Activity个数为1。

  • effectiveUid为当前task所属Uid,mCallingUid为调用者Uid=u0a94,mCallingPackage为调用者包名,这里是com.sina.weibo;

  • realActivity:task中的已启动的Activity组件名com.sina.weibo/.SplashActivity。


场景4:查询某个App的进程状态


dumpsys activity p com.sina.weibo



  • 格式:ProcessRecord{Hashcode pid:进程名/uid},进程pid=7306,进程名为com.sina.weibo:PluginP03,uid=10094.

  • 该进程中还有Services,Connections, Providers, Receivers,可以看出该进程是没有Activity的进程。


其他


还有很多场景,会用到不同的参数,这里就不再一一列举,建议大家多去尝试,慢慢地就更加熟练,再比如:


dumpsys activity top //当前界面app状态

dumpsys activity oom //进程oom状态


专栏作者简介( 点击 → 加入专栏作者 


gityuan:Android全栈工程师:上至能写App,中间能改framework和Native代码,下至能调驱动,全栈能解决性能与稳定性。(新浪微博:@Gityuan)

打赏支持作者写出更多好文章,谢谢!




 关注「安卓应用频道」

看更多精选安卓技术文章
↓↓↓