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

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

要回复文章请先登录注册

w***@163.com

w***@163.com

回复 DCloud_heavensoft :
你好,请问 我在iphone 6 plus 上 拍照后再点击 use photo 时候 就会有一定几率app崩溃,请问是什么原因,怎么优化
2019-07-02 20:33
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 娜娜佳 :
希望在社区发个详细的帖子,说明下在什么机型、什么rom版本上会遇到这个问题,给其他开发者分享经验
2019-06-17 22:37
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 娜娜佳 :
这是webview的内部实现,可能不同版本的chrome内核事件顺序不一样,只能开发者自己写代码规避,我们无法调整webview的内部实现
2019-06-17 22:36
娜娜佳

娜娜佳

回复 DCloud_heavensoft :
发现问题了,document.documentElement.clientWidth在页面开头可能会取到0值,也就是说浏览器document变量居然不一定是加载html的时候就先准备好的......仅在部分机型上可发现,建议修复一下
2019-06-17 10:27
飘过大山

飘过大山

回复 DCloud_heavensoft :
为啥我刚刚还可以云打包,我用1.8.2的编辑器云打包的,而且没出现问题呀
2019-06-14 17:51
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 飘过大山 :
1.8.2已经不能云打包了。但2.0也一样支持非自定义组件模式
2019-06-14 17:44
飘过大山

飘过大山

回复 DCloud_heavensoft :
上面文章说当HBuilderX发布2.0时,云打包机将不再支持1.8的打包。我现在暂时不想更新版本,继续使用1.8.2版本非自定义模式,未来几个月打包不会出现问题吧
2019-06-14 16:52
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 飘过大山 :
正式版已经是2.0.1了,关闭hx重新检查下更新
2019-06-14 16:44
飘过大山

飘过大山

请问什么时候发布HBuilderX发布2.0,我一直在用1.8的打包,升级版本有些插件有出问题就没升级
2019-06-14 16:36
DCloud_heavensoft

DCloud_heavensoft (作者)

回复 娜娜佳 :
这种情况一般是前端代码写的有问题,看看js或css,不同手机浏览器内核不一样
2019-06-14 16:20