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

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

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

使用Android Studio 自带的monitors查找App CPU 使用率过高的原因_第1张图片

双击我绿色框标记的这个按钮,就会生成这么一个文件,如图:
使用Android Studio 自带的monitors查找App CPU 使用率过高的原因_第2张图片

看,上图就一目了然的看到了耗费CPU 都有哪些方法。此时点击黑色的文本,还能看到耗费CPU的明细:
使用Android Studio 自带的monitors查找App CPU 使用率过高的原因_第3张图片

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

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

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

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

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


你可能感兴趣的:(使用Android Studio 自带的monitors查找App CPU 使用率过高的原因)