以前項目裏一直有個iOS8 [UIScrollView(UIScrollViewInternal) _notifyDidScroll] crash的問題,存在了好久,後來復現問題,返現是動畫執行過程當中執行pop 的問題
場景:在商品詳情頁加車以後 作了滑動到下面的商品推薦位置, 當動畫尚未執行完畢, 就POP回上個頁面,就會發生以下Crash
Crashed: com.apple.main-thread
0 libobjc.A.dylib 0x195287bdc objc_msgSend + 28
1 UIKit 0x18876fbbc -[UIScrollView(UIScrollViewInternal) _notifyDidScroll] + 72
2 UIKit 0x1884acdb4 -[UIScrollView setContentOffset:] + 500
3 UIKit 0x188562a98 -[UITableView setContentOffset:] + 300
4 UIKit 0x188646234 -[UIAnimator(Static) _advanceAnimationsOfType:withTimestamp:] + 316
5 QuartzCore 0x187e2629c CA::Display::DisplayLinkItem::dispatch() + 32
6 QuartzCore 0x187e26134 CA::Display::DisplayLink::dispatch_items(unsigned long long, unsigned long long, unsigned long long) + 324
7 IOKit 0x184c01470 IODispatchCalloutFromCFMessage + 376
8 CoreFoundation 0x1839f2dc4 __CFMachPortPerform + 180
9 CoreFoundation 0x183a07a54 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 56
10 CoreFoundation 0x183a079b4 __CFRunLoopDoSource1 + 436
11 CoreFoundation 0x183a05934 __CFRunLoopRun + 1640
12 CoreFoundation 0x1839312d4 CFRunLoopRunSpecific + 396
13 GraphicsServices 0x18d1476fc GSEventRunModal + 168
14 UIKit 0x1884f6fac UIApplicationMain + 1488
15 ZZKKO 0x100393c74 main (main.m:16)
16 libdyld.dylib 0x1958f2a08 start + 4
緣由: iOS8系統下 ViewController被 控制器pop出堆棧之後 ,tableView 已經被release掉,可是 代理方法 仍舊會試圖調用 send 消息 到 它的delegate方法。
解決辦法
- (void)dealloc {
self.tableView.delegate = nil;
self.tableView.dataSource = nil;
}