使用Android Studio 自带的monitors查找App CPU 使用率过高的原因

最近遇到一个问题,就是我们的应用多打开几个页面,直接就卡死了。一般一个应用卡死,无外乎是CPU使用过高,或者内存消耗过大。如果是内存泄露导致的内存消耗过大,那么至少几十个甚至上百个Activity泄露才会导致卡死不动。而我们的应用是多打开几个页面就卡死了,那我猜测是CPU 消耗过高引起的。

什么情况下会消耗CPU 呢,就是大量的运算。那么此时目标就很明确了。就是去查找是哪个Activity或者哪个方法有一直不停止的运算消耗CPU(比如:不停止的while 或者for 循环)。刚开始我走了弯路,用肉眼去检查代码,后来发现效率太低。此时想起了Android Studio 自带的monitor ,注意我红色框和绿色框标记的位置。


双击我绿色框标记的这个按钮,就会生成这么一个文件,如图:

看,上图就一目了然的看到了耗费CPU 都有哪些方法。此时点击黑色的文本,还能看到耗费CPU的明细:

于是问题就清晰明了。原来是EaseSmileUtils.addSmiles()方法在大量消耗CPU 。我打开这个方法看了下,原来里面对TextView的所有字符while遍历,遍历的同时又嵌套了一层for 循环。而当我的页面的TextView特别多时,这些循环加一次就能执行上万次。所以导致CPU 瞬间上升。

我对这个循环嵌套进行了优化,无论打开多少个Activity 都不会出现CPU飙升了,问题就解决了。

此外,Android Monitor 的工具还可以查看内存泄露,网络连接流量使用。都是很使用的工具。少年,去发掘吧。

=====================================

如果你觉得帮到了你,请给作者打赏一口饭吃:


  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值