adb shell使用总结
文章目录
- 日志记录系统概览
- adb 使用方式
- adb命令
- 日志过滤
- 按照告警等级进行过滤
- 按照tag进行过滤
- 根据告警等级和tag进行联合过滤
- 屏蔽系统和其他App干扰,仅仅关注App自身日志
- 查看“当前页面”Activity
- 文件传输
- 截屏和录屏
- 安装、卸载App
- 启动activity
- 其他
日志记录系统概览
Android 日志记录系统是系统进程 logd 维护的一组结构化环形缓冲区。这组可用的缓冲区是固定的,并由系统定义。
最相关的缓冲区为:main(用于存储大多数应用日志)、system(用于存储源自 Android 操作系统的消息)和 crash(用于存储崩溃日志)。
每个日志条目都包含一个优先级(VERBOSE、DEBUG、INFO、WARNING、ERROR 或 FATAL)、一个标识日志来源的标记以及实际的日志消息。
adb 使用方式
- android 手机打开USB调试模式
- 将platform-tool配置到windows的path环境变量中
- 将手机和PC使用数据线连接
adb命令
内容不全面,这里仅仅记录经常使用到的命令。
日志过滤
使用的代码片段如下:
findViewById(R.id.btn).setOnClickListener((view) -> {Log.d("ABC", "aaa");Log.d("aoe", "aaa");Log.i("ABC", "aaa");Log.w("ABC", "aaa");Log.e("ABC", "aaa");});
- 打印日志
adb logcat
执行这条命令,控制台很快刷屏,可见必须要进行过滤。
- 清空日志
adb logcat c
按照告警等级进行过滤
- 显示警告级别以上的信息
C:\Users\biobase>adb logcat *:W
--------- beginning of system
--------- beginning of main
...
07-26 17:44:08.607 30248 30248 W ABC : aaa
07-26 17:44:08.607 30248 30248 E ABC : aaa
...
- 显示错误级别以上的信息
C:\Users\biobase>adb logcat *:E
--------- beginning of system
--------- beginning of main
...
07-26 17:44:08.607 30248 30248 E ABC : aaa
...
所有告警等级对应的标签:**V** :Verbose 详尽的打印内容**D** :Debug 默认打印内容**I** :Info 提示打印内容**W** :Warn 警告打印内容**E** :Error 错误打印内容**F** :Fatal 崩溃打印内容**S** :Silent 不打印这些告警等级逐渐提高 eg. W时会打印E信息,E时不会打印W信息
按照tag进行过滤
C:\Users\biobase>adb logcat -s ABC
--------- beginning of system
--------- beginning of main
07-26 17:44:08.607 30248 30248 D ABC : aaa07-26 17:44:08.607 30248 30248 I ABC : aaa07-26 17:44:08.607 30248 30248 W ABC : aaa07-26 17:44:08.607 30248 30248 E ABC : aaa
根据告警等级和tag进行联合过滤
C:\Users\biobase>adb logcat -s ABC:W
--------- beginning of system
--------- beginning of main
07-30 14:38:51.436 14709 14709 W ABC : aaa
07-30 14:38:51.436 14709 14709 E ABC : aaa
屏蔽系统和其他App干扰,仅仅关注App自身日志
- 获取进程id
C:\Users\biobase>adb shell ps | findstr com.biobase.helloxx
u0_a1282 18409 607 3967996 122424 0 0 S com.biobase.helloxxC:\Users\biobase>
其中第二列18409是进程id
- 仅仅显示指定进程id打印的App信息
C:\Users\biobase>adb logcat -b main -v color --pid 18409
07-30 14:55:11.880 18409 18409 W Choreographer: OPTS_INPUT: First frame was drawed before optimized, so skip!
07-30 14:55:25.503 18409 18409 W ActivityThread: handleWindowVisibility: no activity for token android.os.BinderProxy@2983ba707-30 15:11:11.137 18409 18409 D ABC : aaa
07-30 15:11:11.137 18409 18409 D aoe : aaa
07-30 15:11:11.137 18409 18409 I ABC : aaa
07-30 15:11:11.137 18409 18409 W ABC : aaa
07-30 15:11:11.137 18409 18409 E ABC : aaa
07-30 15:11:11.272 18409 18409 D ABC : aaa
07-30 15:11:11.272 18409 18409 D aoe : aaa
07-30 15:11:11.272 18409 18409 I ABC : aaa
查看“当前页面”Activity
当接手别人的项目或者页面跳转关系复杂时,特别有用
C:\Users\biobase>adb shell dumpsys activity | findstr ResumedActivitymResumedActivity: ActivityRecord{c44ad9a u0 com.miui.gallery/.activity.InternalPhotoPageActivity t4130}ResumedActivity: ActivityRecord{c44ad9a u0 com.miui.gallery/.activity.InternalPhotoPageActivity t4130}
文件传输
在知道具体路径的情况下,文件传输可以非常方便.
- 将PC文件传输到手机
adb push d:/a.txt /sdcard/
- 将手机文件传输到PC
C:\Users\biobase\Desktop>adb pull /sdcard/bluetooth .
/sdcard/bluetooth/: 10 files pulled, 0 skipped. 25.0 MB/s (10782875 bytes in 0.411s)
截屏和录屏
- 截屏
C:\Users\biobase\Desktop>adb shell screencap /sdcard/a.pngC:\Users\biobase\Desktop>
为了应对经常截图的需要,稍微学习了一下windows脚本。将下面的内容保存成bat文件,双击一下,手机屏幕截图就到PC上了。
@ECHO OFF
adb shell screencap -p /sdcard/screen.png
adb pull /sdcard/screen.png "%~dp0\screen.png"
ren screen.png "%date:~0,4%%date:~5,2%%date:~8,2%%time:~0,2%%time:~3,2%%time:~6,2%.png"
adb shell rm /sdcard/screen.png@ECHO ON
- 录制视频
adb shell screenrecord /sdcard/movie.mp4
按Ctrl+C停止。
要进一步控制视频的录制,请看下面的参数说明
1|grus:/ $ screenrecord --h
Usage: screenrecord [options] <filename>Android screenrecord v1.2. Records the device's display to a .mp4 file.Options:
--size WIDTHxHEIGHTSet the video size, e.g. "1280x720". Default is the device's maindisplay resolution (if supported), 1280x720 if not. For best results,use a size supported by the AVC encoder.
--bit-rate RATESet the video bit rate, in bits per second. Value may be specified asbits or megabits, e.g. '4000000' is equivalent to '4M'. Default 20Mbps.
--bugreportAdd additional information, such as a timestamp overlay, that is helpfulin videos captured to illustrate bugs.
--time-limit TIMESet the maximum recording time, in seconds. Default / maximum is 180.
--verboseDisplay interesting information on stdout.
--helpShow this message
安装、卸载App
- 安装App
adb install -r AndroidTest.apk
这里添加 -r 参数可以在不卸载旧版的情况下,进行版本升级(保留App缓存内容)。
- 卸载APP
adb uninstall com.example.androidtest
启动activity
在复杂App开发中,会比较常用。可以跳过手动点击一层层跳转,直接打开某页面。
adb shell am start com.example.androidtest/.MainActivity
or
adb shell am start com.example.androidtest/com.example.androidtest.MainActivity
这里有一个前提条件,就是页面是可启动的。应用首页或者明确设置exported=true
<intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter>or<activityandroid:name=".SignatureActivity"android:exported="true"></activity>
其他
- 清除App数据
adb shell pm clear com.example.androidtest
- 使用默认浏览器打开一个URL
adb shell am start -a android.intent.action.VIEW -d http://www.baidu.com
- 关闭/打开手机屏幕
adb shell input keyevent 26
- 查看手机屏幕分辨率
C:\Users\biobase\Desktop>adb shell wm size
Physical size: 1080x2340
- 模拟点击按键
adb shell input keyevent 4 (BACK) 返回键
adb shell input keyevent 3 (HOME)
相关文章:
![](https://www.ngui.cc/images/no-images.jpg)
adb shell使用总结
文章目录 日志记录系统概览adb 使用方式 adb命令日志过滤按照告警等级进行过滤按照tag进行过滤根据告警等级和tag进行联合过滤屏蔽系统和其他App干扰,仅仅关注App自身日志 查看“当前页面”Activity文件传输截屏和录屏安装、卸载App启动activity其他 日志记录系统概…...
![](https://www.ngui.cc/images/no-images.jpg)
UG NX二次开发(C++)-Tag的含义、Tag类型与其他的转换
文章目录 1、前言2、Tag号的含义3、tag_t转换为int3、TaggedObject与Tag转换3.1 TaggedObject定义3.2 TaggedObject获取Tag3.3 根据Tag获取TaggedObject4.Tag与double类型的转换1、前言 在UG NX中,每个对象对应一个tag号,C++中,其类型是tag_t,一般是5位或者6位的int数字,…...
![](https://img-blog.csdnimg.cn/cbaac9dbb2744327a54b14079b940127.png#pic_center)
Informer 论文学习笔记
论文:《Informer: Beyond Efficient Transformer for Long Sequence Time-Series Forecasting》 代码:https://github.com/zhouhaoyi/Informer2020 地址:https://arxiv.org/abs/2012.07436v3 特点: 实现时间与空间复杂度为 O ( …...
![](https://img-blog.csdnimg.cn/65a55fb793f440b2b350d5935553ef05.png)
c语言位段知识详解
本篇文章带来位段相关知识详细讲解! 如果您觉得文章不错,期待你的一键三连哦,你的鼓励是我创作的动力之源,让我们一起加油,一起奔跑,让我们顶峰相见!!! 目录 一.什么是…...
![](https://img-blog.csdnimg.cn/e21512a218df4fedbcfd4625ca911f13.png)
FFmpeg aresample_swr_opts的解析
ffmpeg option的解析 aresample_swr_opts是AVFilterGraph中的option。 static const AVOption filtergraph_options[] {{ "thread_type", "Allowed thread types", OFFSET(thread_type), AV_OPT_TYPE_FLAGS,{ .i64 AVFILTER_THREAD_SLICE }, 0, INT_MA…...
![](https://img-blog.csdnimg.cn/ee04fdbfc7544ed2bf2853523a966652.png)
CAN学习笔记3:STM32 CAN控制器介绍
STM32 CAN控制器 1 概述 STM32 CAN控制器(bxCAN),支持CAN 2.0A 和 CAN 2.0B Active版本协议。CAN 2.0A 只能处理标准数据帧且扩展帧的内容会识别错误,而CAN 2.0B Active 可以处理标准数据帧和扩展数据帧。 2 bxCAN 特性 波特率…...
![](https://img-blog.csdnimg.cn/221634902fe24de286adb7360d4b90c4.png)
软工导论知识框架(二)结构化的需求分析
本章节涉及很多重要图表的制作,如ER图、数据流图、状态转换图、数据字典的书写等,对初学者来说比较生僻,本贴只介绍基础的轮廓,后面会有单独的帖子详解各图表如何绘制。 一.结构化的软件开发方法:结构化的分析、设计、…...
![](https://www.ngui.cc/images/no-images.jpg)
[SQL挖掘机] - 算术函数 - abs
介绍: 当谈到 SQL 中的 abs 函数时,它是一个用于计算数值的绝对值的函数。“abs” 代表 “absolute”(绝对),因此 abs 函数的作用是返回一个给定数值的非负值(即该数值的绝对值)。 abs 函数接受一个参数&a…...
![](https://www.ngui.cc/images/no-images.jpg)
vue拼接html点击事件不生效
vue使用ts,拼接html,点击事件不生效或者报 is not defined 点击事件要用onclick 不是click let data{name:测,id:123} let conHtml <div> "名称:" data.name "<br>" <p class"cursor blue&quo…...
![](https://www.ngui.cc/images/no-images.jpg)
【Spring】Spring之依赖注入源码解析
1 Spring注入方式 1.1 手动注入 xml中定义Bean,程序员手动给某个属性赋值。 set方式注入 <bean name"userService" class"com.firechou.service.UserService"><property name"orderService" ref"orderService"…...
![](https://img-blog.csdnimg.cn/1fa0db9e419045efa43314747e28ec93.png)
【微软知识】微软相关技术知识分享
微软技术领域 一、微软操作系统: 微软的操作系统主要是 Windows 系列,包括 Windows 10、Windows Server 等。了解 Windows 操作系统的基本使用、配置和故障排除是非常重要的。微软操作系统(Microsoft System)是美国微软开发的Wi…...
![](https://www.ngui.cc/images/no-images.jpg)
12.python设计模式【观察者模式】
内容:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变的时候,所有依赖于它的对象得到通知并被自动更新。观者者模式又称为“发布-订阅”模式。比如天气预报,气象局分发气象数据。 角色: 抽象主题…...
![](https://img-blog.csdnimg.cn/b56c463b171a4bdc91b52079f64d954e.png)
重生之我要学C++第五天
这篇文章主要内容是构造函数的初始化列表以及运算符重载在顺序表中的简单应用,运算符重载实现自定义类型的流插入流提取。希望对大家有所帮助,点赞收藏评论,支持一下吧! 目录 构造函数进阶理解 1.内置类型成员在参数列表中的定义 …...
![](https://img-blog.csdnimg.cn/9b03c8afdef54f4cbe622bc51aa6708c.png)
复习之linux高级存储管理
一、lvm----逻辑卷管理 1.lvm定义 LVM是 Logical Volume Manager(逻辑卷管理)的简写,它是Linux环境下对磁盘分区进行管理的一种机制。 逻辑卷管理器(LogicalVolumeManager)本质上是一个虚拟设备驱动,是在内核中块设备和物理设备…...
![](https://img-blog.csdnimg.cn/67a87e3d031843f08d306cbe693da372.png)
HuggingGPT Solving AI Tasks with ChatGPT and its Friends in Hugging Face
总述 HuggingGPT 让LLM发挥向路由器一样的作用,让LLM来选择调用那个专业的模型来执行任务。HuggingGPT搭建LLM和专业AI模型的桥梁。Language is a generic interface for LLMs to connect AI models 四个阶段 Task Planning: 将复杂的任务分解。但是这里…...
![](https://www.ngui.cc/images/no-images.jpg)
java工程重写jar包中class类覆盖问题
结论:直接在程序中复写jar中的类即可 原因:一般我java工程是运行在tomcat容器中,tomcat容易在加载我们工程类和jar包是的优先级为: 我们工程的class 先于 我们工程lib下的jar 重复的类只加载一次,加载我们复写后的类后…...
![](https://www.ngui.cc/images/no-images.jpg)
Mybatis基于注解与XML开发
文章目录 1 关于SpringBoot2 关于MyBatis2.1 MyBatis概述2.2 MyBatis核心思想2.3 MyBatis使用流程3 MyBatis配置SQL方式3.1 基于注解方式3.1.1 说明3.1.2 使用流程3.1.3 常用注解 3.2 基于XML方式3.2.1 相比注解优势3.2.2 使用流程3.2.3 常用标签 1 关于SpringBoot SpringBoot…...
![](https://img-blog.csdnimg.cn/img_convert/ace1d5697b6a1e7ac748291ab22098dd.jpeg)
数字化转型导师坚鹏:数字化时代扩大内需的8大具体建议
在日新月异的数字化时代、复杂多变的国际化环境下,扩大内需成为推动经济发展的国家战略,如何真正地扩大内需?结合本人15年的管理咨询经验及目前实际情况的深入研究,提出以下8大具体建议: 1、制定国民收入倍增计划。结…...
![](https://img-blog.csdnimg.cn/84023e7db82946c4b9c48605b98719cc.png)
M1/M2 通过VM Fusion安装Win11 ARM,解决联网和文件传输
前言 最近新入了Macmini M2,但是以前的老电脑的虚拟机运行不起来了。😅,实际上用过K8S的时候,会发现部分镜像也跑不起来,X86的架构和ARM实际上还是有很多隐形兼容问题。所以只能重新安装ARM Win11,幸好微软…...
![](https://www.ngui.cc/images/no-images.jpg)
Linux中显示系统正在运行的进程的命令
2023年7月29日,周六上午 在Linux中,ps命令用于显示当前系统中正在运行的进程, ps应该是processes snapshot(进程快照)的缩写。 以下是ps命令的常见用法和示例: 显示当前用户的所有进程:ps 显示…...
![](https://img-blog.csdnimg.cn/683bf56bb89446dc92989163534b93f3.png)
vite中安装less
使用vite创建的项目,默认是没有安装less的 如果直接在style中书写less 会报下图错误: 解决方案: npm install --save less 在package.json中查看是否安装成功 安装完成刷新页面,问题解决...
![](https://img-blog.csdnimg.cn/41241f00bf904b06aa1ae0e531693ae4.png)
Aduino中eps环境搭建
这里只记录Arduino2.0以后版本:如果有外网环境,那么可以轻松搜到ESP32开发板环境并安装,如果没有,那就见下面操作: 进入首选项,将esp8266的国内镜像地址填入,然后保存,在开发板中查…...
![](https://img-blog.csdnimg.cn/b79da7219d2a4cf285617994020806e0.png)
python——案例二 求两个数的和
#案例二 求两个数的和 num1input(请输入第一个数字:) num2input(请输入第二个数字:) sumfloat(num1)float(num2) #计算公式 print(sum) #显示结果 输入num11、num22得到结果sum3...
![](https://img-blog.csdnimg.cn/img_convert/074f8e6209effd644873ef202e13a5d2.png)
一文了解 Android 车机如何处理中控的旋钮输入?
前言 上篇文章《从实体按键看 Android 车载的自定义事件机制》带大家了解了 Android 车机支持自定义输入的机制 CustomInputService。事实上,除了支持自定义事件,对于中控上常见的音量控制、焦点控制的旋钮事件,Android 车机也是支持的。 那…...
![](https://img-blog.csdnimg.cn/11ae640cfaa84d67a995f5fe31e57343.jpeg)
小红书推广 方法总结
大家好,我是网媒智星,今天跟大家分享一下小红书的推广方法和经验。 一、平台简介 1、什么是小红书? 小红书是一个消费决策/生活方式平台,用户可以通过图片、文案、视频等方式分享美好生活。 2、用户画像 - 2亿月活跃…...
![](https://img-blog.csdnimg.cn/266cc1ed21ac4dce9e32a41cd2bae22a.jpeg)
通讯录的实现(超详细)——C语言(进阶)
目录 一、创建联系人信息(结构体) 二、创建通讯录(结构体) 三、define定义常量 四、打印通讯录菜单 五、枚举菜单选项 六、初始化通讯录 七、实现通讯的的功能 7.1 增加加联系人 7.2 显示所有联系人的信息 7.3 单独查…...
![](https://img-blog.csdnimg.cn/img_convert/b49db12e198d73dfa16a8bb70a06c447.jpeg)
3D 渲染技巧-如何创建高质量写实渲染?
掌握创建高质量建筑渲染和任何 3D 渲染的艺术是一项复杂且需要技巧的工作,通常需要多年的经验和实践。实现逼真的结果需要仔细考虑众多因素,并避免可能导致缺乏真实性的假渲染效果的常见错误。 避免常见错误 - 提升渲染游戏的技巧 在追求创建真正逼真的…...
![](https://www.ngui.cc/images/no-images.jpg)
fastadmin采坑之获取当前登录admin用户的信息
在controller层里想要获取当前登录admin用户的信息 print_r($this->auth->getUserInfo());但是有个问题 我在fa_admin表中添加了新的字段,这个方法获取不到新字段的数值,具体也没有去研究估计跟方法有关 然后我直接用模型去获取数据,简…...
![](https://img-blog.csdnimg.cn/59b4aa2214954a2493290a7cfb52995d.png)
【Spring AOP + 自定义注解 + 动态数据源 实现主从库切换读写分离】—— 案例实战
💧 S p r i n g A O P 主从数据源切换 读写分离 自定义注解案例实战! \color{#FF1493}{Spring AOP 主从数据源切换 读写分离 自定义注解 案例实战!} SpringAOP主从数据源切换读写分离自定义注解案例实战!💧 …...
![](https://img-blog.csdnimg.cn/fc650321b61141609d663721af752a84.png)
【LeetCode每日一题合集】2023.7.24-2023.7.30
文章目录 771. 宝石与石头代码1——暴力代码2——位运算集合⭐(英文字母的long集合表示) 2208. 将数组和减半的最少操作次数(贪心 优先队列)2569. 更新数组后处理求和查询⭐⭐⭐⭐⭐(线段树)TODO2500. 删除…...
![](/images/no-images.jpg)
武汉网站建设哪家好/网络推广软件有哪些
根据规划, 调试OsgEarth源码每周1800行源码抄写。 目前鬼火引擎8377行。正好从8月22日开始,到9月底,5周完成。 即:分配到周,应该达到下面的目标。 8月29日时,剩6577行(实际6438行,完…...
![](https://img-blog.csdnimg.cn/img_convert/c24be933261c11ab1483bcd1a9046fa8.png)
建筑模型网站/武汉seo网站优化排名
今天来跟大家分享一个通道指标,一个趋势型指标,供大家参考交易思路思维!大家要明白一点就是指标一定是存在滞后性的,所以不要盲目的崇拜指标所谓的圣杯,交易市场根本就不存在圣杯!1)顺势操盘,多…...
企业网站建设费用入什么科目/关键词优化排名费用
MOSS Search学习记录(一):开启Search服务从今天开始研究学习MOSS的搜索部分,首先就要启动MOSS的搜索服务。 1.搜索服务的启动在MOSS的管理中心中。首先打开MOSS的管理中心。 2.单击上面的“操作选项卡”。在…...
![](/images/no-images.jpg)
做公司网站要素/google play应用商店
大家好,我是小马老师。 本文介绍lammps in文件中使用混合键势的方法。 在以前的推文中,介绍比较多的是混合对势的写法(pair_style hybrid),其实,在同一个模拟体系内,键势类型也可以使用混合势,对应命令为bo…...
![](/images/no-images.jpg)
wordpress 文章关联/广告推广费用一般多少
[JLOI2011]飞行路线 二维spfa,不过需要优化,用优先队列比较快,手打普通队列应该也可以 #include<iostream> #include<cstdio> #include<cstring> #include<queue> #define maxn 10005 using namespace std; int n,m,…...
![](/images/no-images.jpg)
医程通 网站做的太/网站及推广
洛谷 P2505 旅行 题解 洛谷 P2502 解题思路 将速度从小到大排 枚举断点 连接两个点 假如起点可到达终点 更新答案 输出记得化简 代码 #include<algorithm> #include<iostream> #include<cstdio> using namespace std; int xx,yy,ta,wo,n,m,s,t; double …...