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中使用Handler机制更新UI的两种方法
- Android(安卓)Handler解析和相关问题
- android字体闪烁动画(线程)
- Android消息处理机制4——Looper
- google 开发者自定义view的系列(创建view,绘制,交互,view的优化)
- 【Android】SQLite使用
- Android之SurfaceView学习
- Android(安卓)小代码集
- 多线程实现更新android进度条。