每年一次的iOS升级,都会给开发者带来一些适配工作,一些原本工作正常的代码可能就会发生崩溃。 本文讲到了一种 CoreFoundation 对象的内存管理方式在iOS13上遇到的问题。
1. 问题
iOS 13 Beta 版本上,手淘出现了一个必现的崩溃:
Thread 0 name: Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0 libobjc.A.dylib 0x00000001d6f9af20 objc_retain + 16
1 CFNetwork 0x00000001d7843f60 0x1d77b0000 + 606048
2 CFNetwork 0x00000001d780cec8 0x1d77b0000 + 380616
3 CFNetwork 0x00000001d77dff24 _CFSocketStreamCreatePair + 56
4 xxxxxxxxxxxxxxxxx 0x000000010c2a44b4 0x10b46c000 + 14910644
5 xxxxxxxxxxxxxxxxx 0x000000010c2a6238 0x10b46c000 + 14918200
6 xxxxxxxxxxxxxxxxx 0x000000010c2a661c 0x10b46c000 + 14919196
崩溃在了 _CFSocketStreamCreatePair
方法里面, 然后崩溃在了 objc_retain
里面,推测是传入的某个ObjC的对象野指针了导致的。
通过追溯源码,发现调用的是 CFStreamCreatePairWithSocketToHost
这个方法,然后找到这个方法的定义:
void CFStreamCreatePairWithSocketToHost(
CFAllocatorRef _Null_unspecified alloc,
CFStringRef _Null_unspecified host,
UInt32 port,
CFReadStreamRef _Null_unspecified * _Null_unspecified readStream,
CFWriteStreamRef _Null_unspe