0%

Android Adb 调试命令集合

一些实用的命令


发送广播关闭USB

$ adb shell am broadcast -a android.hardware.usb.action.USB_STATE --ez connected "false"

关闭gyroscope(陀螺仪)

硬件相关,可能有变动

$ adb shell echo 0 > /sys/class/sensors/bmg160/enable

无线adb连接手机

How to connect devices via Wireless ADB

Connect the device to the computer with a USB cable → The computer recognize the device

$ adb devices

Make sure device's Wifi is ON, and set device's tcpip port → To change the adb port

$ adb tcpip 12443

Write down the device IP (Connect to wifi):

   Go to settings → about phone → Status → IP address

Example: 192.168.8.81

$ adb connect 192.168.8.81:12443

Disconnect the cable

$ adb disconnect 192.168.8.81:12443

查看系统时间

$ adb shell date

开机跳过setupWizard正常使用

a. disable SetupWizard:

$ adb shell pm list packages | grep setup
$ adb shell pm disable

→ Example: com.google.android.setupwizard

b. build Provision and push into handset:

~$ mmm packages/apps/Provision/
~$ adb push out/target/product/flash3/system/app/Provision/Provision.apk /system/app/Provision/

c. reboot

$ adb reboot

Provision就是无界面版的SetupWizard,快速设置并初始化手机,是SetupWizard的替代版。

可断开USB还执行adb命令

  • 例如通过如下命令记录event log到sdcard
$ adb shell "getevent -ltr > sdcard/getevent.log&"  (linux common function)

在执行此命令之后可拔掉USB进行测试

查看Notification:“找出状态栏广告的主人”

adb shell dumpsys statusbar

强制卸载应用(笔者补充)

adb shell pm uninstall -k --user 0 包名

还原预置应用(笔者补充)

adb shell cmd package install-existing 包名

直接截屏(笔者补充)

adb exec-out "screencap -p" > screencap.png

adb exec-out 对比 adb shell 能够保持管道原样输出。如果使用 adb shell 来实现,会得到一张损坏的图片(https://stackoverflow.com/questions/13578416/read-binary-stdout-data-like-screencap-data-from-adb-shell)。

debug相关的命令


过滤log篇

  • 只查看某个TAG的某个priority的log:
$ adb logcat ActivityManager:I MyApp:D *:S

*:S: sets the priority level for all tags to "silent", thus ensuring only log messages with "ActivityManager" and "MyApp" are displayed.

  • 只显示Error级别的log:
$ adb logcat *:E
  • 直接看Exception的命令:
$ adb logcat -s */E
  • logcat时可以查看某个tag的所有log:
$ adb logcat -v threadtime -s [TAG]
  • 打开某个class的log:
$ adb shell setprop log.tag.MyAppTag VERBOSE
or:
  Creating a local.prop file as described in the original question:
  log.tag.MY_TAG=VERBOSE

  And then pushing it onto the device as follows seems to do the trick:
  adb push local.prop /data/local.prop
  adb shell chmod 644 /data/local.prop
  adb shell chown root.root /data/local.prop
  adb reboot

You can double check to make sure that the values in local.prop were read by executing:
adb shell getprop | grep log.tag
  • 抓取kernel log:
$ adb shell cat /proc/kmsg > kernel.log

强制让进程gc

$ adb shell kill -10 PIDXXX

强制生成trace

/data/anr/traces.txt

$ adb shell kill -3 PIDxxx

强制生成trace(笔者补充)

$ adb shell debuggerd -j PIDxxx > /sdcard/traces.txt

强制生成进程的内存镜像

分析OOM

$ adb shell am dumpheap PIDxxx /data/xxx.hprof

打印内存使用情况(笔者补充)

$ adb shell procrank
$ adb shell free -h
$ adb shell cat /proc/meminfo
$ adb shell dumpsys meminfo
$ adb shell dumpsys meminfo {packagename}

打印调用顺序

在java代码中加入,可知道该函数被谁调用

Debug.getCallers(4)

top命令

每隔1秒执行top命令显示10行数据,能够实时查看后台哪些进程或者线程在执 行,消耗cpu

$ adb shell top -d 1 -m 10 -t

软重新:

$ adb shell stop; adb shell start

monkey test的命令:

$ adb shell monkey -v -p [package name] [times]
$ adb shell monkey -v -p com.jrdcom.lockscreen 1000000

查看cpu频率:

$ adb shell cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_cur_freq
$ adb shell cat /sys/devices/system/cpu/cpu1/cpufreq/scaling_cur_freq
$ adb shell cat /sys/devices/system/cpu/cpu2/cpufreq/scaling_cur_freq
$ adb shell cat /sys/devices/system/cpu/cpu3/cpufreq/scaling_cur_freq

打开CPU loading log:

分析ANR(MTK)

$ adb shell setprop events.cpu true

在events log中实时打印cpu信息。

$ adb logcat -b events | grep cpu
   I/cpu     (  743): [16,4,12,0,0,0]
   I/cpu     (  743): [15,2,13,0,0,0]
   I/cpu     (  743): [16,2,14,0,0,0]

   数字都是百分比,分别为:[total, user, system, iouat, irq, softlrq]``

终端输入play pause事件模拟按键:

$ adb shell media
  usage: media [subcommand] [options]
  media dispatch KEY
  media remote-display

    media dispatch:    dispatch a media key to the current media client.
    KEY may be:        play, pause, play-pause, mute, headsethook, stop, next, previous, rewind, recordm fast-forword.
    media remote-display: 	 monitor remote display updates.

系列核心命令


模拟输入事件:

$ adb shell input text <string>   input a string to device
$ adb shell input keyevent <event_code>   send a Key Event to device

如: adb shell input keyevent 26      (PowerKey)

模拟启动activity:

$ adb shell am start  <INTENT> : start an Activity

如:am start -n com.android.calculator/com.android.calculator2.Calculator

$ adb shell am broadcast <INTENT>

得到/设置settings数据库键值

usage: settings [--user NUM] get namespace key

    settings [--user NUM] put namespace key value

    settings [--user NUM] delete namespace key

 

'namespace' is one of {system, secure, global}, case-insensitive

If '--user NUM' is not given, the operations are performed on the owner user.

$ adb shell settings get/set Global airplane_mode_on
  • 修改数据库的键值:
$ adb shell settings put system/global [key] [value]
$ adb shell settings put system navigation_bar_key_mode 1
  • 得到数据库的键值:
$ adb shell settings get system/global [key]

查看Service信息

  • 查看Service列表:
$ adb shell service list
     Found 1 services:
0 phone: [com.android.internal.telephony.ITelephony]
  • 检查Service是否存在:
$ adb shell service check phone
Service phone: found
  • 使用Service:
$ adb shell service call phone 2 s16 "10086"

手机屏幕相关设置-wm命令

$ adb shell wm

usage: wm [subcommand] [options]

    wm size [reset | WxH]

    wm density [reset | DENSITY]

    wm overscan [reset | LEFT,TOP,RIGHT,BOTTOM]

  • wm overscan [reset|LEFT,TOP,RIGHT,BOTTOM]

    wm overscan: set overscan area for display.

    重新设置屏幕大小、尺寸:



    让界面显示在靠左200,靠上300,靠右400,靠下500的显示区域

      width = displaywidth - left - right

      height = displayheight - top - bottom
$ adb shell wm overscan 200,300,400,500
                     left,top,right,bottom
  • wm size: return or override display size.

    查看屏幕分辨率
$ adb shell wm size
    Physical size: 720x1280
  • wm density: override display density.
$ adb shell wm density
    Physical density: 480

      强制设置手机dpi为320

$ adb shell wm density 320

$ adb shell wm density reset

svc命令

Turn on/off Wi-Fi

$ svc wifi [enable|disable]

Turn on/off mobile data

$ svc data [enable|disable]

手机重启

$ svc power reboot [reason]
  Perform a runtime shutdown and reboot device with specified reason.

手机关机

$ svc power shutdown
  Perform a runtime shutdown and power off the device.

pm 命令大全

pm命令用于分析手机中apk和包名

查看当前安装的所有apk

$ adb shell pm list packages
  package:com.android.defcontainer
  package:com.tencent.mm

查看包名和文件名对应表

$ adb shell pm list packages -f
  package:/system/priv-app/DefaultContainerService.apk=com.android.defcontainer
  package:/data/app/com.tencent.mm-1.apk=com.tencent.mm
  package:/system/app/JrdGallery.apk=com.jrdcom.gallery3d

查看disable packagename

$ adb shell pm list packages -d

查看enable packagename

$ adb shell pm list packages -e

查看system app packagename

$ adb shell pm list packages -s

查看第三方app packagename

$ adb shell pm list packages -3

其他

$ adb shell pm list features

# Enable/Disable package
$ adb shell pm enable [packagename]
$ adb shell pm disable [packagename]

am 命令大全

强制dump某个进程的内存镜像

# 1044是Launcher的pid
$ adb shell am dumpheap 1044 /data/aa.hprof

Dalvik's sampling profiler 定时抓取java call stack

$ adb shell am profile start [--user <USER_ID> current] [--sampling INTERVAL] <PROCESS> <FILE>
$ adb shell am profile stop [--user <USER_ID> current] [<PROCESS>]

  $ persist.sys.profiler_ms 		时间频率 默认0
  $ persist.sys.profiler_depth	 call stack depth 默认4

抓取的文件保存于/data/snapshots/<pid>-<time>.snapshot

List all of the activity stacks and their sizes

$ adb shell am stack list

Display the information about activity stack <STACK_ID>

$ adb shell am stack info <STACK_ID>

dumpsys相关命令


  • 查看activity的provider信息

查看activity每个数据库的调用信息查询
打印所有provider信息 可以查看数据库某个时间点的增删改查的次数, 监测应用的IO操作:

$ adb shell dumpsys activity provider all

PROVIDER ContentProviderRecord{19861e6e u0 com.android.providers.media/.MediaProvider} pid=31295
    Client:
      internal.db: version 700, 68 rows, 0 inserts, 0 updates, 0 deletes, 120 queries,
      1970-02-07 10:49:01.893 : Database upgraded from version 63 to 700 in 0 seconds
												               插入62次,0次更新,0次删除,105次查询
      1970-02-07 10:49:03.852 : internal.db: version 700, 54 rows, 62 inserts, 0 updates, 0 deletes, 105 queries, scan started Feb 7, 10:49 AM (00:02)
      1970-02-07 10:54:06.555 : internal.db: version 700, 54 rows, 0 inserts, 0 updates, 0 deletes, 55 queries, scan started 2月7日 下午6:54 (00:00)
      2013-12-26 05:41:19.318 : internal.db: version 700, 54 rows, 0 inserts, 4 updates, 0 deletes, 58 queries, scan started Dec 26, 1:41 PM (00:00)
      2013-12-27 07:45:37.775 : internal.db: version 700, 59 rows, 0 inserts, 0 updates, 0 deletes, 55 queries, scan started Dec 27, 3:45 PM (00:00)
  • 查看provider的Connections,谁在连接数据库
$ dumpsys activity providers
  • 查看手机disk状态
$ adb shell dumpsys diskstats
    >> Latency: 5ms [512B Data Write]
    >> Data-Free: 362888K / 1161104K total = 31% free
    >> Cache-Free: 116756K / 120900K total = 96% free
    >> System-Free: 133036K / 806284K total = 16% free
  • Get the list of services available:
$ adb shell service list
  • 查看可用的SERVICE列表
$ adb shell dumpsys | grep 'DUMP OF SERVICE' | awk '{print $4}' | tr -d ':'

ACTIVITY MANAGER PENDING INTENTS (adb shell dumpsys activity intents)
ACTIVITY MANAGER BROADCAST STATE (adb shell dumpsys activity broadcasts)
ACTIVITY MANAGER CONTENT PROVIDERS (adb shell dumpsys activity providers)
ACTIVITY MANAGER SERVICES (adb shell dumpsys activity services)
ACTIVITY MANAGER ACTIVITIES (adb shell dumpsys activity activities)
ACTIVITY MANAGER RUNNING PROCESSES (adb shell dumpsys activity processes)
INPUT MANAGER (adb shell dumpsys input)
WINDOW MANAGER LAST ANR (adb shell dumpsys window lastanr)
WINDOW MANAGER POLICY STATE (adb shell dumpsys window policy)
WINDOW MANAGER SESSIONS (adb shell dumpsys window sessions)
WINDOW MANAGER TOKENS (adb shell dumpsys window tokens)
WINDOW MANAGER WINDOWS (adb shell dumpsys window windows)
  • 查看某个应用的内存使用信息

getting memory usage informations

$ adb shell dumpsys meminfo 'your apps package name'
$ adb shell dumpsys meminfo com.google.android.apps.maps
  • 查看TaskStack
$ adb shell dumpsys activity activities
  • 查看Alarm列表
$ adb shell dumpsys alarm
  • 查看surface flinger:
$ adb shell dumpsys SurfaceFlinger
  • dumpsys其他一些信息:
adb shell dumpsys SurfaceFlinger | grep "Layer\|z="
adb shell dumpsys activity log a on
adb shell dumpsys window -d enable 26
adb shell dumpsys alarm log on
adb shell dumpsys alarm log off
adb shell dumpsys window policy
adb shell dumpsys activity log anr 2   可以打开anr的messagequeue
adb shell dumpsys activity a           查看activity详细信息,如显示大小,布局等等
adb shell dumpsys activity processes   进程信息 trimmemory
adb shell dumpsys activity recents
adb shell dumpsys activity broadcasts  可以查看前台和后台broadcast详细信息(发送时间,
                                       所有应用处理时间,监听广播的所有列表)
adb shell dumpsys activity intents
adb shell dumpsys activity oom
adb shell dumpsys input | grep Focus   查看焦点窗口

转载自: https://cwgoover.github.io/2016/10/09/android-adb-usage/