Weex-iOS内存分析

前言

引入weex提高了业务开发的效率以及灵活度,但是在使用过程中还是存在不少问题,其中内存上就有很明显的问题

一、weex页面与原生页面对比存在的内存问题

1、weex页面内存开销过大

如图进行页面切换:


在进行到weex页面的时候内存暴涨。

2、页面Push跳转堆栈内存泄漏。

从首页Push跳转到weex页面,加载数据,再返回,重复多次得出下图的结果:

而Push跳转到原生页面再返回,重复多次得出下图内存结果:

从上面两张图可以看出:原生页面返回后从堆栈移除后会进内存回收;而从weex页面回到首页,内存没有完全回收,存在一定的内存泄漏,重复多次可以看到内存相比较一开始会有明显的增加。

3、列表滑动的内存情况

在没有采用<list>和<cell>标签的情况下:

weex页面列表滑动内存情况如图:
weex页面滑动内存情况

通过趋势图列表滑动过程中内存一直持续暴涨,没有进行复用减少内存开销。

原生页面列表滑动内存情况如图:
原生页面滑动内存情况

从图中可以看到,在滑动初始阶段,内存增长比较快,之后的滑动过程中对前面的控件进行复用,内存开销减少,曲线变得平缓,没有出现内存持续暴涨。

4、 weex页面内存问题总结:

1、weex页面滑动没有采用复用机制,导致内存会跟着滑动持续暴涨
2、weex页面占用内存开销过高,多个weex页面可能导致APP因为内存过大而Crash。
3、weex页面从堆栈移除内存没有完全回收,存在一定的内存泄漏。

二、内存问题原因分析

1、滑动过程内存持续暴涨问题

weex官方文档上,建议使用高性能可复用<cell><list>,而【搜索页】、【乐疯抢】等weex页面业务代码中直接采用了<div><scroller>实现列表的布局,导致内存问题的出现。

这里我们通过Weex源码,对四个标签进行分析

可以在WXSDKEngine 中可以看出各个标签对应的类:

<div> 对应WXComponent
<scroller>对应WXScrollerComponent
<cell>对应WXCellComponent
<list>对应WXListComponent
<div>

<div>对应的WXComponent 相当于原生iOS控件的UIView,是所有视图的基类,一个普通的视图没有性能优化、复用回收的机制。

<scroller>

<scroller>对应的WXScrollerComponent结构如下:


并无相关复用回收的属性,主要是提供一个可以滑动的容器。

<cell>

查看<cell>对应WXCellComponent类的实现代码可以发现,WXCellComponent相比较WXComponent 拥有复用回收的相关属性isRecycle

<list>

<list>对应的WXListComponent的结构如图:


在成员列表中可以看到使用了iOS原生的UITableView,并且实现了使用了UITableView的代理方法,实现了iOS的复用机制,如图:

同时WXListComponent实现了WXCellComponent中的代理方法,WXCellComponentWXListComponent相关联系。

因此<list>基于iOS的UITableView复用机制,实现高性能了可复用的列表容器。
结合<cell>可以实现一个高性能的列表展示页面。

因此采用<list><cell>代替<scroller><div>解决滑动列表内存暴涨的问题。

2、weex页面内存开销过高的问题

通过Instrument工具进行内存分析,发现在进入weex 页面时VM ImageIO_GIF_DataVM ImageIO两个对象内存异常暴涨。

VM ImageIO_GIF_Data 内存增长情况:
VM ImageIO 内存增长情况:


VM ImageIO_GIF_Data 由7.92M增长到16.55M,VM ImageIO由0.11M增长到了1.02M,进入Weex页面时,这两个对象总共增加了9.54M,而整个Weex页面初始状态占用内存为15M左右(原生【商品详情】页:7M左右),占据了整个Weex页面内存的约60%。
而在原生页面中,VM ImageIO_GIF_DataVM ImageIO对象几乎没有增长。
而这两个对象与CoreGraphics中进行图片绘制、图片渲染、图片读写等相关方法有关,而CoreGraphics为相对底层的模块,相关方法比较消耗性能、内存,并且容易产生内存泄漏。
初步可以判定,weex中大量调用了CoreGraphics中图片处理的相关方法,导致了weex页面内存开销过大。

接着在WeexSDK的源码中查找CoreGraphics相关方法,定位问题。
在查找过程发现,weex通过CoreGraphics绘图方法将<text>等控件实例绘制成位图进行显示,以适应weex中的CSS布局。
WXComponent+Display 中,可以看到将控件绘制成图片的代码,并在layer上显示:

通过这部分的代码可以定位到weex页面内存开销过大的主要原因是: weex SDK 调用了CoreGraphics方法将页面中的<text>等控件绘制成图片再布局显示,占用了大量的内存。

weex的内存泄漏也与大量调用了CoreGraphics中方法有关。

通过Leaks工具定位到weex页面内存泄漏对象为CGDataProviderCreateWithCopyOfData



CGDataProviderCreateWithCopyOfData为调用CoreGraphics相关方法产生的对象。
weex SDK调用CoreGraphics中的相关方法,但是没有及时地释放对象,导致了内存泄漏。

weex SDK 大量CoreGraphics方法将控件绘制成图片再布局显示,占用了大量的内存,同时也导致了资源回收不及时的问题。

解决方案:

1、限制堆栈中weex页面个数:
天猫采用的也是该方案,通过控制页面级数,控制内存,防止因为堆栈过多的weex页面,内存过大导致异常Crash。
2、页面复用:
在打开weex页面前,判断堆栈中是否有该weex页面,如果有便进行页面复用,通过数据刷新页面,同时通过调整堆栈将页面显示出来。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容