Android性能优化之游戏 OutOfMemoryError: pthread_create探究真相

news2024/12/25 0:42:20

近期,着手分析游戏的OOM问题,该问题在bugly上的量级,恐怖吓人的百万级,处于java 异常的top 1, 如下所示:
在这里插入图片描述
发生的设备,基本上都是32位的cpu架构
在这里插入图片描述

分析过程

先来看下报错的堆栈,基本上都是发生在创建线程的环节:
在这里插入图片描述
单纯从java 报错的调用栈来看,往往会简单的认为是app 线程过多导致OOM。然而,事实真的是如此嘛?

先通过adb shell 来,查询下游戏的线程数
在这里插入图片描述
经历游戏的主流程后,发现线程数并没有增加特别多,普遍处于200多上下,没有到达厂商限制最大线程数(华为 设备上限制500+的线程数)。

从而推断出,并不是线程数量过多导致OOM的问题。

接着继续探究,OOM 是内存不足时,再次申请开辟内存失败,从而抛出的异常。

去查看下会不会是系统内存不足,导致的元凶?
在这里插入图片描述
从bugly上统计的数据来看,游戏发生OOM时,系统可用内存还是很充足的,因此也排除了这个原因。

接着继续,分析看下是不是Dalivk Heap内存不足?

java heap OOM异常,会带着,Failed to allocate a 294920 byte allocation with 147040 free bytes and 143KB until OOM,与报错堆栈上的pthread_create (1040KB stack) failed: Try again完全对不上,因此也不是dalvik 堆内存不足导致的。

排除了三个可能性后,结合32位设备,推断唯一剩下的便是app 的虚拟内存不足。

更多有关于内存情况,请阅读Android 内存分析(java/native heap内存、虚拟内存、处理器内存 )和Android adb shell 查看App内存(java堆内存/vss虚拟内存/详细的内存状况/内存快照hprof)和系统可用内存

32位的进程最大虚拟内存是4G,其中内核空间占1G +用户空间占3G,存在限制

猜想验证

编译一个游戏渠道包,找个32位的设备,安装后。

登录游戏,进入游戏大厅,查看下虚拟内存情况:
在这里插入图片描述
发现虚拟内存Vmsize: 2.9G ,处于正常值。

接着玩几个比较大型的游戏地图:
在这里插入图片描述
再次查看虚拟内存:
在这里插入图片描述
虚拟内存,直线飙升,到3.4G

尝试继续玩不同的地图,也随着记录app的虚拟内存
在这里插入图片描述
在这里插入图片描述
虚拟内存马上接近4G时,线程数任然是192个正常范围,游戏出现黑屏,接着突然闪退。

这时的logcat 输出,线程oom的日志:

2023-06-12 18:29:23.950 23936-24275/? E/Adreno-GSL: <gsl_memory_alloc_pure:2615>: GSL MEM ERROR: kgsl_sharedmem_alloc ioctl failed.
2023-06-12 18:29:23.951 23936-24275/? E/Adreno-GSL: <gsl_memory_alloc_pure:2615>: GSL MEM ERROR: kgsl_sharedmem_alloc ioctl failed.
2023-06-12 18:29:23.953 23936-24275/? E/Adreno-GSL: <gsl_memory_alloc_pure:2615>: GSL MEM ERROR: kgsl_sharedmem_alloc ioctl failed.
2023-06-12 18:29:23.953 23936-24016/? E/AndroidRuntime: FATAL EXCEPTION: miniCrashTask
    Process: com.minitech.miniworld.meta, PID: 23936
    java.lang.OutOfMemoryError: pthread_create (1040KB stack) failed: Try again
        at java.lang.Thread.nativeCreate(Native Method)
        at java.lang.Thread.start(Thread.java:884)
        at okio.AsyncTimeout.scheduleTimeout(AsyncTimeout.java:88)
        at okio.AsyncTimeout.enter(AsyncTimeout.java:80)
        at okio.AsyncTimeout$2.read(AsyncTimeout.java:235)
        at okio.RealBufferedSource.indexOf(RealBufferedSource.java:354)
        at okio.RealBufferedSource.readUtf8LineStrict(RealBufferedSource.java:226)
        at okhttp3.internal.http1.Http1Codec.readHeaderLine(Http1Codec.java:215)
        at okhttp3.internal.http1.Http1Codec.readResponseHeaders(Http1Codec.java:189)
        at okhttp3.internal.http.CallServerInterceptor.intercept(CallServerInterceptor.java:88)
        at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:147)
        at okhttp3.internal.connection.ConnectInterceptor.intercept(ConnectInterceptor.java:45)
        at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:147)
        at okhttp3.internal.http.RealInterceptorChain.proceed(RealInterceptorChain.java:121)

最终,验证了猜想,是32位的app进程存在虚拟内存4G限制,才是导致OOM的罪魁祸首。

总结

在32位的设备上或者沙盒环境(不支持64位cpu)的环境下,游戏很容易发生OOM问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/796350.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Prompt Engineering论文梳理(主要为2022年)

AutoPrompt &#xff08;EMNLP2020&#xff09; Shin T, Razeghi Y, Logan IV R L, et al. Autoprompt: Eliciting knowledge from language models with automatically generated prompts[J]. arXiv preprint arXiv:2010.15980, 2020. 基本架构&#xff0c;original input t…

【历史上的今天】7 月 27 日:模型检测先驱出生;微软收购 QDOS;第一张激光照排的中文报纸

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2023 年 7 月 27 日&#xff0c;在 1961 年的今天&#xff0c;IBM 推出了 IBM Selectric 电动打字机&#xff1b;电动打字机是打字机界无可争议的游戏规则颠覆者&#…

电商-订单模块

电商-订单模块 流程思维图表结构支付中心流程 流程思维图 表结构 支付中心 流程

座舱域控进入“上车”加速期,中国芯片的狂飙时代来了?

智能座舱成为了全球芯片厂商竞逐的下一个战场。 进入2023年&#xff0c;联发科官宣与英伟达合作开发集成CPU粒芯的汽车SoC&#xff0c;为下一代软件定义汽车提供全套车载人工智能座舱解决方案&#xff1b;AMD在特斯拉座舱落地后&#xff0c;与亿咖通在智能座舱领域达成了合作&…

猿辅导AI智能学情分析系统,用科技分析每个的孩子课堂表现

近几年&#xff0c;随着现代科技的不断发展&#xff0c;人们的生活也发生了很大的变化。“翻译神器”让沟通没有了语言障碍&#xff1b;“支付神器”让我们无需携带现金便可轻松消费&#xff0c;方便快捷&#xff1b;科技赋能下的课堂&#xff0c;也让教育从“面对面”传道解惑…

ipad笔买原装还是平替?apple pencil替代品推荐

如今&#xff0c;电容笔在网上办公、网上教育等行业风靡&#xff0c;平替式的电容笔能否取代苹果原来的电容笔吗&#xff1f;在现实生活中&#xff0c;你其实不必要为一支原版的苹果电容笔花费那么多的钱。一支普通的平替电容笔&#xff0c;售价只要一二百块钱&#xff0c;比起…

马上医疗项目介绍

“马上好医”项目白皮书 一、大型医疗挂号微服务“马上好医”医疗项目 “马上好医”即为网上医疗预约挂号系统&#xff0c;首先&#xff0c;由于互联网的发展&#xff0c;衍生出非常多的便民医疗服务的需求&#xff0c;而网上预约挂号则是其中一个便民需求&#xff0c;我们能…

Web3.0实战(02)-联盟链入门讲解

联盟链是介于公有链和私有链之间&#xff0c;具备部分去中心化的特性。 联盟链是由若干机构联合发起&#xff0c;由盟友共同来维护&#xff0c;它只针对特定某个群体的成员和有限的第三方开放。 8.1 部分去中心化 联盟链只属于联盟内部的成员所有&#xff0c;联盟链的节点数…

用友NC65登录界面的jsp页面路径

如上图,访问地址 http://127.0.0.1/portal/app/mockapp/login.jsp?lrid=1对应的页面是哪个呢??相信很多做用友portal端开发的人可能都没有研究或者思考过这个问题,或者想过,但是不知道路径在哪里。你直接按地址栏的地址查,发现nchome里,并没有”portal/app/mockapp/“这…

Centos7 yum命令异常报错:Could not retrieve mirrorlist http://mirrorlist.centos.org

一、问题背景 vmware安装CentOS-7-x86_64-DVD-2009版本后&#xff0c;执行yum -y install gcc报错Could not retrieve mirrorlist http://mirrorlist.centos.org/?release7&archx86_64&repoos&infrastock error was [rootcentos ]# yum -y install gcc 已加载插…

Linux服务器上重置Mysql8密码

前言 此流程适用于mysql 8版本 1. 关闭数据库 1.关闭数据库 service mysqld stop2. 编辑配置文件 1.编辑文件 vim /etc/my.cnf输入 i &#xff0c;进入编辑模式2.添加配置 skip-grant-tables按ESC&#xff0c;再输入 :wq &#xff0c;保存退出3.重启数据库 service…

node中使用jsonwebtoken实现身份认证

在现代web应用中&#xff0c;用户身份认证是非常重要且必不可少的一环。而使用Node.js和Express框架&#xff0c;可以方便地实现用户身份认证。而在这个过程中&#xff0c;jsonwebtoken这个基于JWT协议的模块可以帮助我们实现安全且可靠的身份认证机制&#xff0c;可以让我们轻…

Superset基础安装

Superset 介绍 ​ Superset快速&#xff0c;轻巧&#xff0c;直观&#xff0c;并带有各种选项&#xff0c;使各种技能的用户都可以轻松浏览和可视化其数据&#xff0c;从简单的折线图到高度详细的地理空间图。 1、特点 以下是Superset的主要功能的概述&#xff1a; 开箱即用的…

数据库原理与应用(清华版)第一章书后习题

目录 1.1名词解释 1.2简答 1.3判断 1.4选择题 1.5设计一个学生档案管理系统 1.1名词解释 &#xff08;1&#xff09;数据库(DB)&#xff1a;在计算机的存储设备上合理存放、相关联、有结构的数据集合。 &#xff08;2&#xff09;数据库系统(DBS)&#xff1a;在计算机系统…

拥抱AIGC,他们有话说——百度李双龙:AIGC将赋能多个场域并惠及千行百业

AIGC在人工智能领域爆火&#xff0c;人工智能技术引领代际变革&#xff0c;⽣成式AI在多个场景落地应用&#xff0c;其中⽣成式⼤语⾔模型&#xff08;LLM&#xff09;在通⽤性、多轮对话理解、推理任务中的表现&#xff0c;让世界惊艳。 当前AIGC落地应用进展究竟如何&#x…

蓝牙室内定位-蓝牙定位管理平台功能介绍

蓝牙定位管理平台可以远程快速配置蓝牙定位基站&#xff0c;管理SOS呼救信息&#xff0c;实时定位显示人员、物品位置信息&#xff0c;电子围栏&#xff0c;电子点名&#xff0c;人员或物品移动轨迹记录和查询等。 1、实时定位 在地图上展示人员的实时位置信息&#xff0c;每秒…

团队管理:掌握团队管理的关键神器

什么是团队管理 团队管理是一种协调和领导团队达到共同目标的方法和实践。在今天的竞争激烈的商业环境中&#xff0c;团队管理对于企业的成功至关重要。团队管理不仅仅是指领导者监督团队成员的工作&#xff0c;而是注重协作、沟通和激励&#xff0c;以实现更好的绩效和创造力…

HTML及其标签详解

文章目录 一、HTML简介1、网页1>什么是网页2>什么是HTML 2、Web标准1>为什么需要Web标准2>Web标准的构成 3、HTML语法规范1>基本语法2>标签关系 二、HTML标签1、基本标签2、标题标签3、段落和换行标签4、文本格式化标签5、< div>和< span>标签6、…

css 删除线,价格删除线

text-decoration: line-through;

编写脚本,使用mysqldump实现分库分表备份

进入back_db_v1.sh中 脚本编写如下 运行 验证