首先看一下错误信息如下
java.lang.OutOfMemoryError: pthread_create (1040KB stack) failed: Out of memory at java.lang.Thread.nativeCreate(Native Method) at java.lang.Thread.start(Thread.java:753) at java.util.concurrent.ThreadPoolExecutor.addWorker(ThreadPoolExecutor.java:970) at java.util.concurrent.ThreadPoolExecutor.processWorkerExit(ThreadPoolExecutor.java:1038) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1180) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636) at java.lang.Thread.run(Thread.java:784)
线程创建太多,有代码不合理的地方,如果不确是否线程创建过多可以通过Android studio的Profiler
然后选择CPU可以看见如下
上图的55个线程是不会造成oom 也很好的去模拟,每次请求都new一个新的线程就会增加,如果一直增加不减就会导致oom 此时内存还是属于正常;此时大家内心是不是想说 这个还用你讲,我肯定知道线程创建过多了,怎么去排查代码呢,不急 定位是线程过多,那么我们就需要去验证,不然改了代码还不知道是不是改对了,拿着用户去做实验是不可取的;
存在多次创建线程问题:
1.timer用的时间 每次都new ,原来的没有释放 。(项目中service 中每次都new Timer ,资源浪费 )
2.OKHttpClient 有多个 需要使用单利的方式,不能创建多个请求,每次都创建一个将会是开启多个线程池就达不到复用的效果。
3.频繁创建线程的地方没有用线程池 。
4.项目中 有一个单次定位的 每次都new AMapClient 进行单次定位 , 定位完成没有掉 stopLocation() ,而且定位还在service
5.Rxjava 线程使用尽量不需要每次创建线程 不然没有限制最大线程数讲无限创建;