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