DCloud_heavensoft
DCloud_heavensoft
  • 发布:2019-05-09 21:47
  • 更新:2023-03-31 15:55
  • 阅读:38960

App平台iOS设备上因内存不足导致白屏、闪退的问题解决方案

分类:uni-app

原因

任何手机设备上,当手机内存不足时,os都会回收资源。一般是先回收后台打开的资源。如果当前应用占用的资源过高,当前应用也有可能崩溃。
尤其是在调用摄像头点击拍照时,手机内存占用会达到一个峰值,此时较容易出问题。

iOS上当内存不足时,根据uiwebview和wkwebview的不同,它自身有不同的回收策略。

  • 如果是uiwebview的app(常见于5+app),内存不足时整个app会崩溃,即闪退。
  • 如果是wkwebview的app(uni-app和wap2app在iOS上默认就是wkwebview),内存不足时,单个wkwebview会崩溃。也就是所谓的应用还在,而页面白屏。

这个问题在所有使用wkwebview的应用都会出现,比如微信的公众号网页里也存在。在微信小程序里,它做了一个自动恢复手段,可以让jscore存储数据状态,崩溃的wkwebview自动恢复。所以在遇到问题时,会白一下然后恢复渲染。

解决方案

  • uni-app因为引入了独立的jscore处理数据状态,jscore不会崩溃,所以官方采用了和微信小程序一致的策略,补充自动的白屏恢复能力。
  • uni-app中也可以使用nvue来避免这个问题,nvue页面不会出现内存不足引发的白屏崩溃。
  • 5+app、wap2app,一方面注意前端代码写法,减低内存使用。另外HBuilder2.3.4+开始支持配置WKWebview内核奔溃是重新启动应用还是重新加载页面的配置,详情参考:https://ask.dcloud.net.cn/article/36540。但整体而言,5+app和wap2app在WKWebview下问题很多,还有各种跨域限制,还是建议开发者尽快升级为uni-app。

在前端减少内存使用的注意

最重要的注意,就是图片渲染,尤其是大图片。

在页面上不要渲染多张大图,比如从摄像头或相册选择多张图,并缩放尺寸渲染在页面上,虽然肉眼看起来手机屏幕上是几张小图,但实际上是多张大图只是被缩小,这种情况非常耗费内存。一张图片3m,9张这样的大图同时渲染到屏幕上,什么手机都受不了。
一个缩略图控制在几k或十几k,才是合理的。

详情页面展现多张大图并不受影响。如果图片滚动在屏幕外,os内存不足时也会自动收回这些屏幕外图片占用的渲染资源,最吃资源的就是同屏渲染多张大图。

10 关注 分享
2***@qq.com 2***@qq.com 7***@qq.com s***@163.com 2***@qq.com 5***@qq.com 穷鬼溪风 2***@qq.com h***@163.com DCloud_UNI_HRK

要回复文章请先登录注册

appwociao

appwociao

回复 DCloud_heavensoft :
碰到同样的问题,没有自动恢复。但是不能稳定复现,偶尔出现。
最新版框架离线打包的。
2021-07-11 13:21
niupengyuan

niupengyuan

回复 2***@qq.com :
自己试试
2021-06-18 09:31
2***@qq.com

2***@qq.com

回复 niupengyuan :
onshow生命周期不是拿不到节点吗?
2021-06-11 12:17
你咋骚的一匹

你咋骚的一匹

回复 niupengyuan :
好的感谢
2021-05-27 10:24
niupengyuan

niupengyuan

回复 你咋骚的一匹 :
用的是uniapp的一个方法,可以获取dom节点,如果被回收了也就不存在dom节点了,目前我的应用是只在tabbar页出现过,子页面没有发现,根据自身情况添加
2021-05-26 18:47
你咋骚的一匹

你咋骚的一匹

回复 niupengyuan :
请问你这个方法是什么原理呢,另外只在tabbar页面的onShow调用,若挂后台的时候不在tabbar页面还能监测到吗?
2021-05-26 16:05
niupengyuan

niupengyuan

回复 hxyfj :
tabbar主页面的onshow
2021-05-21 17:55
niupengyuan

niupengyuan

回复 hxyfj :
onshow
2021-05-21 17:53
hxyfj

hxyfj

回复 niupengyuan :
请问 这个该在哪里调用?
2021-04-27 12:08
456vv

456vv

你不能为自己的APP省内存,能吃就吃。其它APP也好不到哪里去。
2021-04-08 22:15