记录最近业务中出现的两个问题

946 阅读1分钟

两个问题都出现在iOS 9上,用户比例大概是在10%左右,还是占了比较大的比例,但我们平时开发所使用的测试机和模拟器都是iOS 10,同时这两个问题出现的场景需要较多的条件,于是问题就这么漏过去了。

1.TTTAttributedLabel的text中包含emoji会引发内存溢出.

https://github.com/TTTAttributedLabel/TTTAttributedLabel/issues/601

上面是这个问题的issue,具体就不分析了,解决办法和原因都在issue里,只是发现这个问题的过程实在太过曲折——运营那边不停在向我们抱怨用户反馈crash,可是fabric上真的干净得如一张白纸(其实也不太干净)啊。

2.UICollectionView dataSource is not set.

iOS9中,UICollectionView removeFromSuperView时,会调用DataSource中的一些方法,此时如果DataSource已经释放,就会出现上图中的crash。iOS 10中UIKit中对这部分逻辑做了改动,因此不会crash了。

而造成DataSource会被提前释放的很大可能原因就是,在构造UICollectionView的实例时,UICollectionView的superView与DataSource生命周期不一致。举例说:在A类中创建了UICollectionView和BView的实例,同时把UICollectionView加入了BView的subviews,但是DataSource设置为了A类,如果A的生命周期比BView要长,那就不会有问题,但是如果A在BView前先被析构了,就会引发crash。

解决办法,在A的dealloc中将UICollectionView提前removeFromSuperView。