最近遇到一个问题,就是我们的应用多打开几个页面,直接就卡死了。一般一个应用卡死,无外乎是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 的工具还可以查看内存泄露,网络连接流量使用。都是很使用的工具。少年,去发掘吧。
=====================================
如果你觉得帮到了你,请给作者打赏一口饭吃: