adb 常用命令

adb 常用命令

ADB的全称为Android Debug Bridge,就是起到调试桥的作用。ADB是android sdk(Android专属的软件开发工具包)里的一个工具, 用这个工具可以直接操作管理android模拟器或者真实的andriod设备。
它的主要功能有:运行设备的shell(命令行);管理模拟器或设备的端口映射;计算机和设备之间上传/下载文件;将本地apk软件安装至模拟器或android设备。

开启/关闭服务

有时候 adb 运行异常,就需要重启关闭开启 adb 服务。

adb kill-server         # 关闭服务
adb start-server        # 开启服务

查看当前连接的设备

示例:

$ adb devices
List of devices attached
192.168.91.185:5555 device

连接 USB 转为 WIFi

  1. 先使用 usb 连接到电脑上。

  2. 设置目标设备以侦听端口 5555 上的 TCP/IP 连接。

    $ adb tcpip 5555
    restarting in TCP mode port: 5555
    
  3. 断开 usb 连接,并访问设备的内部网址

    $ adb connect device_ip_address
    connected to device_ip_address:5555
    
  4. 查看设备是否已连接

    $ adb devices
    List of devices attached
    192.168.2.127:5555  device
    
  5. 断开WiFi 连接的设备

    $ adb disconnect
    disconnected everything
    

给指定设备发送命令

当电脑连接多个设备时,发出 adb 命令,必须指定一个设备

adb -s serial_number command

例如:

adb -s BY2XEE157 install path_to_apk

安装/卸载应用

  1. 安装应用

    adb install path_to_apk
    
  2. 覆盖安装应用

    adb install -r path_to_apk
    
  3. 卸载应用

    adb uninstall com.package.name
    

电脑与设备间的文件复制

  1. 从设备复制文件

    adb pull remote local
    
  2. 复制文件到设备

    adb push local remote
    

在上述命令中,localremote 指的是开发计算机(本地)和模拟器/设备实例(远程)上目标文件/目录的路径。例如:

adb push foo.txt /sdcard/foo.txt

输入设备日志到终端上

  1. 一直显示设备日志,直到你手动 (Ctrl + C) 停止

    adb logcat
    
  2. 将设备缓存的日志输入到终端上,不会阻塞

    adb logcat -d
    
  3. 将日志以文件形式输出到手机设备上,会阻塞,需手动 (Ctrl + C) 停止

    adb logcat -f /sdcard/log.txt
    

    PS:
    (1). 如果在后台自动手机,不阻塞终端,则可在命令最后加一个 & 的参数;
    (2). 加了&的命令,需要在不收集的时候手动停止,否则再次使用该命令时,会造成2个 logcat 的命令都写在同一个文件中。

    停止方法:

    adb shell kill -9 <logcat pid>
    

    其中logcat_pid 通过 如下命令获取

    adb shell ps | grep logcat          # Linux & macOS 平台
    adb shell ps | findstr "logcat"    # Windows 平台
    
  4. 清空日志缓存信息

    adb logcat -c
    
  5. 过滤指定等级以上的日志

    adb logcat "*:<level>"
    

    日志等级列表:

    -- V : Verbose (明细);
    -- D : Debug (调试);
    -- I : Info (信息);
    -- W : Warn (警告);
    -- E : Error (错误);
    -- F : Fatal (严重错误);
    -- S : Silent(Super all output) (最高的优先级, 可能不会记载东西);
    

    示例:命令 $ adb logcat "*:E" ,只显示错误级别以上的日志

查看设备已安装应用

查看设备所有应用包名,包括:系统应用、第三方应用

adb shell pm list package

查看设备所有第三方应用包名

adb shell pm list package -3

清除指定应用的所有数据(不卸载应用)

adb shell pm clear com.package.name

强制关闭应用

adb shell am force-stop com.package.name

截屏

adb shell screencap /sdcard/screen.png

录制视频

adb shell screenrecord /sdcard/demo.mp4

如果需要停止录制视频,需要等待3分钟或输入快捷键Ctrl + C停止,也可以加 --time-limit TIME单位为秒
如:录制5分钟

adb shell screenrecord /sdcard/demo.mp4 --time-limit 300

当然还可以设置分辨率720P

adb shell screenrecord /sdcard/demo.mp4 --size 1280x720

获取输入法

  1. 获取当前设备默认输入法

    adb shell settings get secure default_input_method
    
  2. 设置指定的输入法(设输入法为:com.android/input)为默认

    adb shell ime set com.android/input                 # 两条命令作用一样
    adb shell settings put secure default_input_method com.android/input
    

获取设备信息参数

adb shell getprop

重启手机命令

  1. 重启手机

    adb reboot
    
  2. 重启手机到recovery界面

    adb reboot recovery
    
  3. 重启手机到bootloader界面

    adb reboot bootloader
    
  4. 重启手机到fastboot界面

    adb reboot fastboot
    

获取设备属性

使用命令adb shell getprop+下面的属性,即可获取相应的属性

属性名 含义
ro.build.version.sdk SDK 版本
ro.build.version.release Android 系统版本
ro.product.model 型号
ro.product.brand 品牌
ro.product.name 设备名
$ adb shell getprop ro.product.model
vivo X9i

查看实时资源占用情况

示例:

$ adb shell top

User 4%, System 2%, IOW 0%, IRQ 0%
User 108 + Nice 0 + Sys 68 + Idle 2284 + IOW 0 + IRQ 6 + SIRQ 6 = 2472

  PID PR CPU% S  #THR     VSS     RSS PCY UID      Name
 2003  5   3% S    64 1257132K 154860K  fg u0_a19   com.android.systemui
  521  5   2% D    13 145376K  23044K  fg system   /system/bin/surfaceflinger
19825  4   0% R     1   6516K   1416K  fg shell    top
18585  7   0% S     1      0K      0K  fg root     kworker/u16:2
19563  7   0% D     1      0K      0K  fg root     mdss_fb0
 1452  5   0% S   178 2458344K 190788K  fg system   system_server
19795  7   0% S     1      0K      0K  fg root     kworker/u16:6
17950  7   0% S     1      0K      0K  fg root     kworker/u16:0
   53  4   0% S     1      0K      0K  fg root     rcuop/6
 2151  6   0% S    55 1708748K  76084K  fg system   com.vivo.daemonService

更多用法:

    -m num  显示最多的进程数目
    -n num  刷新多少次后退出
    -d num  刷新时间间隔
    -s col  以什么数据排列 (cpu,vss,rss,thr).
    -t      显示线程信息代替进程
    -h      显示帮助文档

查看内存信息

adb shell dumpsys meminfo                   # 查看整个设备的内存信息
adb shell dumpsys meminfo pid               # 查看指定进程的内存信息
adb shell dumpsys meminfo com.package.name  # 查看指定应用的内存信息

提示:

dalvik:是指dalvik所使用的内存。 native:是被native堆使用的内存。应该指使用C\C++在堆上分配的内存。
VSS- Virtual Set Size 虚拟耗用内存(包含共享库占用的内存)
RSS- Resident Set Size 实际使用物理内存(包含共享库占用的内存)
PSS- Proportional Set Size 实际使用的物理内存(比例分配共享库占用的内存)
USS- Unique Set Size 进程独自占用的物理内存(不包含共享库占用的内存)
一般来说内存占用大小有如下规律:VSS >= RSS >= PSS >= USS

查看指定应用的指定页面启动时间

  1. 可通过启动页面指定页面获得时间
adb shell am start -W -n  com.package.name/.activity
  1. 查看设备日志获得打开指定页面时间
    示例:
$ adb shell logcat | grep ActivityManager

06-22 16:27:43.827  1452  2446 I ActivityManager: START u0 {cmp=com.babychat.parent.test/com.babychat.module.setting.view.SettingAty} from uid 10113 on display 0
06-22 16:27:43.967  1452  1609 I ActivityManager: Displayed com.babychat.parent.test/com.babychat.module.setting.view.SettingAty: +115ms
06-22 16:27:44.847  1452  2158 I ActivityManager: START u0 {act=android.content.pm.action.REQUEST_PERMISSIONS pkg=com.android.packageinstaller cmp=com.android.packageinstaller/.permission.ui.GrantPermissionsActivity (has extras)} from uid 10113 on display 0
06-22 16:27:44.867  1452  2473 I ActivityManager: START u0 {cmp=com.babychat.parent.test/com.babychat.activity.OutBoxActivity (has extras)} from uid 10113 on display 0
06-22 16:27:44.997  1452  1609 I ActivityManager: Displayed com.babychat.parent.test/com.babychat.activity.OutBoxActivity: +117ms
06-22 16:27:46.017  1452 26437 I ActivityManager: START u0 {act=android.content.pm.action.REQUEST_PERMISSIONS pkg=com.android.packageinstaller cmp=com.android.packageinstaller/.permission.ui.GrantPermissionsActivity (has extras)} from uid 10113 on display 0
06-22 16:28:30.527  1452  2446 I ActivityManager: START u0 {cmp=com.babychat.parent.test/com.babychat.activity.UserHomeHistoryAty (has extras)} from uid 10113 on display 0
06-22 16:28:30.687  1452  1609 I ActivityManager: Displayed com.babychat.parent.test/com.babychat.activity.UserHomeHistoryAty: +140ms (total +44s660ms)

查看当前 activity

示例:

$ adb shell dumpsys window | grep mCurrentFocus
mCurrentFocus=Window{2cf7a4d u0 com.babychat.parent.test/com.babychat.module.chatting.groupmemberlist.GroupMemberListActivity}

获取流量

adb 命令获取流量有多种方式。

需提前准备的数据

  1. 获取指定应用的 pid

    adb shell ps | grep com.package.name
    

    如:

    $ adb shell ps | grep com.babychat.parent.test
    u0_a113   9483  773   2033552 243156 SyS_epoll_ 0000000000 S com.babychat.parent.test
    u0_a113   9518  773   1603852 48948 SyS_epoll_ 0000000000 S com.babychat.parent.test:pushservice
    

    其中logcat_pid 通过 如下命令获取

    adb shell ps | grep logcat          # Linux & macOS 平台
    adb shell ps | findstr "logcat"     # Windows 平台
    

    第二列的数值就是 pid

  2. 获取指定应用的 uid

    adb shell cat /proc/<pid>/status
    

    PS:pid 第一点获取的数值
    如:

    $ adb shell cat /proc/2076/status
    Name:   hat.parent.test
    State:  S (sleeping)
    Tgid:   9483
    Pid:    9483
    PPid:   773
    TracerPid:  0
    Uid:    10113   10113   10113   10113
    Gid:    10113   10113   10113   10113
    Ngid:   0
    FDSize: 256
    Groups: 3003 9997 50113 
    VmPeak:  2210788 kB
    VmSize:  2033632 kB
    VmLck:         0 kB
    VmPin:         0 kB
    VmHWM:    362872 kB
    VmRSS:    244244 kB
    VmData:   378084 kB
    VmStk:      8196 kB
    VmExe:        20 kB
    VmLib:    121404 kB
    VmPTE:      1772 kB
    VmSwap:        0 kB
    Threads:    170
    SigQ:   0/13358
    SigPnd: 0000000000000000
    ShdPnd: 0000000000000000
    SigBlk: 0000000000001204
    SigIgn: 0000000000000000
    SigCgt: 00000002000094f8
    CapInh: 0000000000000000
    CapPrm: 0000000000000000
    CapEff: 0000000000000000
    CapBnd: 0000000000000000
    Seccomp:    0
    Cpus_allowed:   ff
    Cpus_allowed_list:  0-7
    voluntary_ctxt_switches:    17297
    nonvoluntary_ctxt_switches: 10150
    

    命令结果中第7行就是 uid 的结果了

1、读取/proc/uid_stat/<UID> 目录下的文件

流量数据分为接收流量(tcp_rcv)和发送流量(tcp_snd)两部分,这两个状态数值我们可以通过读取/proc/uid_stat/<UID>目录下的两个文件得到。

$ adb shell cat /proc/uid_stat/10114/tcp_rcv
100046432
$ adb shell cat /proc/uid_stat/10114/tcp_snd
2020511

PS:

  1. 以上命令只能获取 TCP 协议的流量,UDP 等其他协议没有计算在内;
  2. 以上数据的单位为(Byte),且此数据是一直累加的,直到卸载应用才会删除
  3. 使用以上方法获取流量,需在操作前和操作后各获取一次数据,得到得到之间的相差值就可以了。

2、读取/proc/net/xt_qtaguid/stats | grep <uid> 流量数值

通过使用以下命令获取设备流量信息,如果指定应用,则获取应用的 uid,在该命令后添加参数| grep uid

adb shell cat /proc/net/xt_qtaguid/stats

如:

$ adb shell cat /proc/net/xt_qtaguid/stats | grep 10114
40 wlan0 0x0 10114 0 6306390 5007 276578 3966 6306390 5007 0 0 0 0 276578 3966 0 0 0 0
41 wlan0 0x0 10114 1 104210738 82998 5295286 65789 104210738 82998 0 0 0 0 5295286 65789 0 0 0 0

PS:

  1. 第6列是接收的流量数值,单位:bytes;
  2. 第8列是发送的流量数值,单位:bytes;
  3. 如果结果出现多行数据,相加的总数即为结果

3、读取 /proc/<pid>/net/dev 数值

通过获取到的 pid ,使用命令可得到:

$ adb shell cat /proc/<Pid>/net/dev

Inter-|   Receive                                                |  Transmit
 face |bytes    packets errs drop fifo frame compressed multicast|bytes    packets errs drop fifo colls carrier compressed
rmnet_ipa0:     716       7    0    0    0     0          0         0      880      12    0    0    0     0       0          0
r_rmnet_data7:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
r_rmnet_data4:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
rmnet_data1:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
rmnet_data3:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
 wlan0: 320261121 1225926    0  124    0     0          0         0 28315746  159136    0    0    0     0       0          0
rmnet_data5:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
r_rmnet_data1:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
rmnet_data7:     620       8    0    0    0     0          0         0      880      12    0    0    0     0       0          0
dummy0:       0       0    0    0    0     0          0         0      210       3    0    0    0     0       0          0
  p2p0:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
r_rmnet_data6:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
r_rmnet_data3:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
r_rmnet_data8:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
rmnet_data0:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
r_rmnet_data0:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
rmnet_data2:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
rmnet_data4:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
  sit0:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
    lo:    2272      27    0    0    0     0          0         0     2272      27    0    0    0     0       0          0
r_rmnet_data5:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
rmnet_data6:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0
r_rmnet_data2:       0       0    0    0    0     0          0         0        0       0    0    0    0     0       0          0

PS:
1.wlan0 代表是 WiFi 接收发送的流量数值,单位为:bytes

获取电量

未完待续

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容