Android oom pthread_create (1040KB stack)分析及解决

首先看一下错误信息如下

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

Android oom pthread_create (1040KB stack)分析及解决_第1张图片

然后选择CPU可以看见如下

Android oom pthread_create (1040KB stack)分析及解决_第2张图片

上图的55个线程是不会造成oom    也很好的去模拟,每次请求都new一个新的线程就会增加,如果一直增加不减就会导致oom  此时内存还是属于正常;此时大家内心是不是想说  这个还用你讲,我肯定知道线程创建过多了,怎么去排查代码呢,不急 定位是线程过多,那么我们就需要去验证,不然改了代码还不知道是不是改对了,拿着用户去做实验是不可取的;

 

存在多次创建线程问题:

1.timer用的时间 每次都new  ,原来的没有释放 。(项目中service 中每次都new Timer ,资源浪费 )

2.OKHttpClient 有多个  需要使用单利的方式,不能创建多个请求,每次都创建一个将会是开启多个线程池就达不到复用的效果。

3.频繁创建线程的地方没有用线程池 。

4.项目中 有一个单次定位的 每次都new AMapClient 进行单次定位 , 定位完成没有掉 stopLocation() ,而且定位还在service 

5.Rxjava 线程使用尽量不需要每次创建线程 不然没有限制最大线程数讲无限创建;
 

 

Android oom pthread_create (1040KB stack)分析及解决_第3张图片

 

 

你可能感兴趣的:(android,android提高能力,android开发,android)