前面大概学习了adb基础,但是adb的存在,在测试人员中究竟有什么必要,以及看log时,那么多的log,让我们看个屁啊,所以这一次,我决定一定要把adb这件事情搞清楚。

1.先来看最感兴趣的adb日志

首先来了解一共概念,安卓的日志有那些:

Android 系统的日志分为两部分,底层的 Linux 内核日志输出到 /proc/kmsg,Android 的日志输出到 /dev/log。一般我们说的adb logcat看的都是android的日志

使用adb shell dmesg 可以能看Android的内核日志,内核日志我们可以做一些事情,比如衡量内核启动时间,在系统启动完毕后的内核日志里找到 Freeing init memory 那一行前面的时间就是。

内核启动时间看了有啥用呢?

科普文章链接:https://blog.csdn.net/u010164190/article/details/51396485

作为测试做常用的adb查看日志命令:

1.adb logcat -v time   打印log的详情日志

2.adb logcat -v time > D:\log.txt   把日志输出到电脑的上查看,在窗口打印的同时,文件也会同时打印的

3.adb logcat -c       清除之前的日志信息,一般在看日志前都会执行这个命令,目的是好看日志,不然前面的日志应该会超级多,不好看问题

2.过滤规则

有两种规则,一种是按照日志级别过滤,一种是按照日志中的tag过滤,当然会有混合日志和tag在一起过滤

过滤格式:

adb logcat <tag>[:priority]

tag表示标签,priority输出的级别,注意如果要是要根据级别查看时记得要tag一定要给,如果没有指定,那个tag哪里输入*号就行了

日志级别过滤:

默认级别为V,输出人日志最低,日志级别最低

D —— Debug

I —— Info

W —— Warning

E —— Error

F —— Fatal  致命

S —— Silent(最高,啥也不输出)

实例:比如想要查看手机的级别为错误的日志

adb logcat *:E(不区分大小写)

tag级别过滤:

用这个过滤首先要知道手机上的tag,可以用这个命令查看手机日志的tag

adb logcat -v tag

输出后格式会是:<priority>/<tag>: <message>

但是在日志中的tag究竟是什么意思呢?标签,顾名思义,但是还是不明白,后面明白再来看这快

现在我要知道的就是tag如何过滤日志,可以使用下面的命令:

adb logcat ActivityManager:I

发现tag过滤并没有生效,为啥??

而网上下面这个命令却是生效的:

adb logcat ActivityManager:I PowerManagerService:D *:S

组合起来的使用其实再这里也讲了

3,使用管道进程来查看日志,这个应该是最好的

adb logcat | grep MyApp
adb logcat | grep -i myapp #忽略大小写。

后期强大的话,还可以使用正则表达式来学习

再windows上不能使用grep关键字,而是应该用findstr

只抓取某个app的命令

adb logcat | findstr app进程号

如何只查看某个app日志的方法

1.adb shell pm list packages -3 查看非系统第三方应用包名

2.adb shell ps | findstr vchat.A  查看包名进程

3.根据进程来查看过滤app的日志

adb logcat | findstr vchat.A

遇到问题:查看app日志时,日志打印到一半莫名报错,写入错误?

原因如下:adb logcat  findstr 有时候会出现 写入错误,需要设置一下语言编码CHCP 65001 ,设置为UTF-8编

命令行中,有个命令是chcp,这个命令是用来显示当前活动代码页编号的,

 ANSI的编码环境的代号是936

 utf-8编码的65001

执行:CHCP 65001就设置成utf-8编码的了

其他常用命令:

一、把日志输出到手机指定目录

其命令为:adb logcat -f / sdcard/zjdata.bredbaby/log/1.txt

二,很多没用的一起加载,如果只想抓取被测app的日志,就需要对包名进行过滤,使用find过滤包名

adb logcat find | "vchat.A"

常用命令:

常用命令

1、查看adb版本

adb version

2、查询pc链接的所有android 设备

adb devices

3、装包

如果在电脑D盘下面有个a.apk文件,只需要一行命令就安装到手机上:

adb install d:/a.apk

如果已经安装了这个程序,可以通过以下命令覆盖安装:adb install -r d:/a.apk

保留数据和缓存文件,重新安装 apk adb install -r a.apk

安装包在android设备中

adb shell pm install apk在移动端的路径

4、卸载包

adb uninstall 包名

卸载软件但是保留配置和缓存文件:

adb uninstall -k 包名

如果机器上有多个模拟器或真机,需要使用-s命令行参数指定具体的模拟器或真机。例如,下面的命令分别在模拟器和真机上安装、重新安装和卸载应用程序。

在emulator-5554模拟器上安装ebook.apk

adb -s emulator-5554 install ebook.apk

在真机上安装ebook.apk

adb -s HT9BYL904399 install ebook.apk

在emulator-5554模拟器上重新安装ebook.apk

adb -s emulator-5554 install -r ebook.apk

在真机上重新安装ebook.apk

adb -s HT9BYL904399 install -r ebook.apk

在emulator-5554模拟器上卸载ebook.apk(不保留数据和缓冲目录)

adb -s emulator-5554 uninstall ebook包名

在真机上卸载ebook.apk(保留数据和缓冲目录)

adb -s HT9BYL904399 uninstall -k ebook包名

5、包管理,如何知道一个app包名呢

包名(Package name)在Android系统中是判断一个App的唯一标识,不同的App可以有同样的名字,但是它的包名不可以相同。

例如我们可以自己编译生成一个App也叫“微信”,但是我们的App的包名不能为com.tencent.mm

(微信的包名为这个),如果指定的包名和微信一致,那么手机上只允许安装这两个App中的其中一个。说到这很多人就会有疑问,如果有人恶意做了一个和微信内容一模一样的App,名字和包名都和微信一样,那怎么分辨呢?Android中为了防止这样的情况,还做了一个叫签名的东西,微信的签名一般我们是没有的,所以就可以通过签名来标识出这款App到底是谁的了。

1、看源代码。当有源代码的时候,可以到工程目录下的 “AndroidManifest.xml”文件下查看package这一项。

2、adb命令查看列出手机装的所有 app 的包名:

adb shell pm list packages

3.列出系统应用的所有包名:

adb shell pm list packages -s

4.列出除了系统应用的第三方应用包名:

adb shell pm list packages -3

5.推测一个包中可能带有的关键字:

adb shell dumpsys activity | findstr mFocusedActivity

6.清除应用数据与缓存

adb shell pm clear 应用包名

6、文件相关

1、接收电脑文件

语法:adb push local remote

案例:adb push d:/a.txt /sdcard/

把电脑 D 盘下的 a.txt 文件推送到手机 sdcard 目录下

2、上传文件到电脑

语法:adb pull remote local

案例:adb pull /sdcard/a.txt d:/ 上传位于/sdcard/目录下的 a.txt 文件到电脑的 D 盘根目录下

7、截屏、录屏

1.截屏

adb shell screencap /sdcard/a.png

adb shell /system/bin/screencap -p /sdcard/a.png

2.使用adb进行屏幕录像

adb shell screenrecord /sdcard/a.mp4

通过ctrl+c停止录制,你可以在sdcard目录下查看。妈妈再也不担心我到处找录制视频的软件了。

8、shell

进入shell adb shell

退出shell

exit

9、手机信息收集

获取序列号

adb get-serialno

获取 MAC 地址

adb shell cat /sys/class/net/wlan0/address

查看设备型号

adb shell getprop ro.product.model

查看 Android 系统版本

adb shell getprop ro.build.version.release

查看屏幕分辨率

adb shell wm size

查看屏幕密度

adb shell wm density

查看permissions adb shell pm list permissions

查看系统的危险权限dangerous permissions adb shell pm list permissions -d -g

10、adb服务器杀死和启动

adb kill-server

adb start-server

场景:比如希望移动adb文件夹,或者adb命令得不到想要的内容时

11、与进程相关:

列出当前进程

adb shell ps | findstr 包名

杀死某个包的进程

adb shell am force-stop 包名

12、与性能相关的一些内容

获取内存:

adb shell dumpsys meminfo 包名

获取cpu:

adb shell dumpsys cpuinfo | findstr 包名

adb shell top -n 1 | findstr 包名

获取流畅度相关:

adb shell dumpsys gfxinfo 包名

13、app的启动停止

如果想在模拟器或真机上运行已安装的应用程序,除了直接在模拟器或真机上操作外,还可以使用如下的命令直接运行程序。

activity的获取方式见14条。

在emulator-5554模拟器上运行ebook.apk

adb -s emulator-5554 shell am start -n net.blogjava.mobile.ebook/net.blogjava.mobile.ebook.Main

在真机上运行ebook.apk

adb -s HT9BYL904399 shell am start -n net.blogjava.mobile.ebook/net.blogjava.mobile.ebook.Main

其中Main是ebook.apk的主Activity。相当于Windows应用程序的主窗体或Web应用程序的主页面。am是shell命令。

14、与Activity操作等相关

1.查看当前显示的activity adb shell dumpsys activity | findstr "mFocusedActivity"

结果: mFocusedActivity: ActivityRecord{93a4f9 u0 com.youdao.note/.activity2.MainActivity t36}

注意:我们只需要这一部分:com.youdao.note/.activity2.MainActivity即包名+activity

2.找到当前手机内的top Activity:

adb shell dumpsys activity top | findstr ACTIVITY

3.启动某一个Activity: adb shell am start activity路径

adb shell am start com.youdao.note/.activity2.MainActivity

15、查看8080端口是哪个应用占用

netstat -ano|findstr "8080"

adb shell top -n 1 | findstr vchat.faceme

感谢:https://www.cnblogs.com/YouxiYouxi/

adb进阶知识,如何过滤只查看某一个app的日志相关推荐

  1. adb过滤只查看某一个app的日志

    作为测试做常用的adb查看日志命令: adb logcat -v time 打印log的详情日志 adb logcat -v time > D:\log.txt 把日志输出到电脑的上查看,在窗口 ...

  2. 分享一个app内日志查看工具

      很早之前为上家公司写过一个日志查看搜索的组件,方便在开发,内测阶段调试bug.但是感觉不太满意,最近自己 重新完善了一下,开源给大家.主要完善的内容如下: 1,每次app杀死,重新启动都会新创建一 ...

  3. react只停留在表层?五大知识点带你梳理进阶知识

    五大知识点带你梳理react进阶知识 ✉️前言

  4. adb查看app的日志

    adb命令查看app的日志,网络的先连接,usb的插上就能用了. adb logcat *:E ->d:\\log.txt 在做app测试的时候,经常会遇到异常,此时如果开发没有异常保存,那么测 ...

  5. MariaDB/Mysql数据库进阶知识

    这一篇章主要说一下关于MariaDB/Mysql的一些进阶知识,希望可以加深自己的理解 MariaDB的特性 插件式存储引擎:也称为"表类型",存储管理器有多种实现版本,功能和特性 ...

  6. JavaScript 进阶知识 - Ajax篇

    Ajax 前言 前面我们已经学习了js基础知识和一些简单的特效,基本上已经能够写出一个带有特效的静态页面了,为什么还要称之为静态页面呢?因为网页里的数据都是写死的,真正的工作中,我们是要通过Ajax技 ...

  7. adb命令查看app的日志

    前言 在做app测试的时候,经常会遇到异常,此时如果开发没有异常保存,那么测试就得通过adb命令来查看日志信息.基于Windows平台的操作: logcat输出日志 一.把日志输出到手机指定目录 其命 ...

  8. [django框架2]ORM进阶知识

    经过上周的django学习与项目实战,想必对其也有了足够的了解. django基础知识 项目实战 本次django进阶知识重要围绕数据库管理操作为主,同时讲述了部分关于组件中间件的内容,希望有所帮助. ...

  9. Win32 OpenGL编程(4) 2D图形基础(颜色及坐标体系进阶知识)

    Win32 OpenGL 编程 (4) 2D 图形基础(颜色及坐标体系进阶知识) write by 九天雁翎 (JTianLing) -- blog.csdn.net/vagrxie 讨论新闻组及文件 ...

最新文章

  1. 【Python】Label组件 Button组件 Checkbutton组件
  2. 操作系统之磁盘调度——SCAN实例讲解
  3. mysql在linux下显示花_在Linux 中搭建 Mysql
  4. 算法设计与分析——递归与分治策略——最接近点对问题
  5. 东方希望上云 告诉你数字化门槛儿到底有多高?
  6. 怎么去掉ECSHOP的Powered by ECShop版权信息
  7. Linux安全 chage sudo授权 selinux安全上下文 gpg加密 aide入侵检测系统 audit 审计
  8. java mvc .net mvc_.NET MVC 和 JAVA MVC有什么区别?
  9. 简单实现x的n次方pta_数学学霸的解题思路1“降低次方和次元”
  10. 按键精灵怎么用 android,按键精灵安卓版怎么用
  11. php mysql敏感词_PHP敏感词处理
  12. 夜神模拟器安装drozer
  13. bzoj3207 花神的嘲讽计划Ⅰ
  14. 安装texthero踩过的坑
  15. AUTOSAR E2E SecOC Comparison
  16. qt开源项目: tiled 瓦片 游戏地图编辑器
  17. 如何把很多照片拼成一张照片_怎样用手机将多张照片拼成一张组合图
  18. html在一行内横向排列并排同行同时显示两个多个div盒子的方法
  19. 基础算法(三) --- 轮询
  20. Go语言爱好者周刊:第 14 期

热门文章

  1. 基础数论算法(4) 中国剩余定理
  2. 服务器omv系统,开源NAS系统OpenMediaVault安装与体验
  3. tensorflow框架精细讲解(一)
  4. android studio 打包cocos creator项目
  5. LINUX磁盘分区和添加磁盘的一些命令
  6. cmake中如何添加fPIC编译选项
  7. Android Snackbar简单解析
  8. leetcode 5473. 灯泡开关 IV medium (智力题,O(n)思路详解)
  9. PAT甲级 A1030
  10. 数据结构初阶——链式二叉树