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

Posted 码农乐园

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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

然后选择CPU可以看见如下

上图的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)分析及解决的主要内容,如果未能解决你的问题,请参考以下文章

Android 逆向Android 进程注入工具开发 ( 远程进程注入动态库文件操作 | 注入动态库 加载 业务动态库 | 业务动态库启动 | pthread_create 线程开发 )

[Android]异常10-java.lang.OutOfMemoryError pthread_create (1040KB stack) failed: Try again

浅谈Android OOM及定位分析

浅谈Android OOM及定位分析

浅谈Android OOM及定位分析

Android内存优化之OOM