adb shell 执行sh脚本_Android之在linux终端执行shell脚本直接打印当前运行app的日志的实现方法...

1、问题

我们一般很多时候会需要在ubuntu终端上打印当前运行app的日志,我们一般常见的做法是

1)、获取包名

打开当前运行的app,然后输入如下命令,然后在第一行TASK后面的就可以看到包名

adb shell dumpsys activity top

2)、我们的终端安装了pidcat.py脚本,然后执行如下的命令就可以打印当前运行app的全日志,

pidcat.py packageName

3)、思考,为什么每次都需要这样重复的操作呢?一说到重复,我们应该立马想到是否可以用脚本解决重复操作

2、解决办法

通过执行脚本文件获取包名,然后再执行pidcat.py packageName命令

3、代码实现

1)、新建pcat文件

#!/bin/bash

dev="device"

devices=$(adb devices)

if [[ ${devices} == *$dev ]]

then

echo "手机已经连接好终端"

info=$(adb shell dumpsys activity top | awk -F " " '/TASK/ {print $2}')

echo "当前运行app的包名是:${info}"

pidcat.py --hw ${info}

else

echo "手机没有连接好终端"

fi

2)、把pcat文件复制到下面目录

/usr/local/bin/

4、测试结果

1)、打开手机"游戏中心"的app

2)、在终端输入pcat

3)、终端运行结果

*****~$ pcat

手机已经连接好终端

当前运行app的包名是:com.huawei.gamebox

Zygote D CtrlSocket libc.so ctrl_sockets_set_addr pfunc is not exist!

Process com.huawei.gamebox created for activity com.huawei.gamebox/.GameBoxActivity

PID: 29758 UID: GIDs:

ActivityThread D ActivityThread,attachApplication

HwCust D Create obj success use class android.content.res.HwCustHwResourcesImpl

AnalyticUtils D experience = 1

StoreApplication D create application.

HwPolicyFactory V : success to get AllImpl object and return....

HwWidgetFactory V : successes to get AllImpl object and return....

ActivityThread V ActivityThread,callActivityOnCreate

5、小结

重复的操作我们可以用脚本解决问题,提高开发效率,要记得用这个之前确保你的终端能运行pidcat

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值