问题引言
近来使用SDWebImage获取网络gif图片时,发现内存猛增。如若再tableview中加载多张gif图片,很快就有内存警告出现,随之程序被系统kill。(如图1所示,原本不到1M的gif,程序运行后,内存占用了78.6M,但是cpu占用很低)
图1--SDWebImage内存占用.png后来发现网络上流行的开源库YYKit,据说对图片处理的很好,就下载下来与SDWebImage进行了对比,发现:相比于SDWebImage,YYKit的内存使用的确是降低了,可是在cpu使用上面,居高不下。(如图2所示,同样的gif图片,程序运行后,内存占用只有10.3M,但是cpu持续占用)
图2--YYKit的cpu使用.png这到底是为什么呢,我们来分析一下看看。
问题分析
首先,先看看SDWebImage运行过程中内存占用过高的问题。
通过instrucment分析,发现SDWebImage处理gif图片的方法是:将gif资源中每一张imgae写入到内存中,通过animatedImageWithImages的方式播放动画。这样的好处是,gif轮询播放时,直接从内存中取资源就好了,降低了cpu的占用。也就是说,SDWebImage是以空间换取的流畅度。
图3--sdwebimage内存占用分析.png
问题就在这里了,每张image占用内存1.2M,所以此gif中包含58张image,就会占用近70M的内存。当程序中的gif多了,就会出现内存警告。
然后,再来看看YYKit的cpu使用问题。
也是通过instrument分析,发现了YYKit处理gif图片的方法是:每次从缓存的gif中,读取当前需要展示的image,进行动画展示。这样做的好处是,不用为gif的每张image开辟空间了,每次都是从一份gif资源中读取一张image就好了。
图4--YYKit的cpu使用分析.png
那这个YYKit的cpu问题,也就不言而喻了,以一定的帧率从缓冲中解析出当前需要展示的image,肯定是需要耗用cpu的。
小结
问题分析也就到这里了,两个开源库各有特点,具体使用哪个,需要根据不同的业务需求决定。
网友评论