我的应用程序的前两个崩溃发生在下面的方法上:
+ (UIImage *)imageWithData:(NSData *)data scale:(CGFloat)scale
到目前为止,它已经发生了2000多次,根据崩溃报告,它以略有不同的方式表现出来:
EXC_BAD_ACCESS KERN_INVALID_ADDRESS at 0x00000004
Thread : Crashed: com.apple.main-thread
0 ImageIO 0x27b6a1b6 CGImagePlusSetImageBlockProc + 41
1 libsystem_malloc.dylib 0x34a5139b calloc + 58
2 ImageIO 0x27b671c5 initImagePng + 4492
3 ImageIO 0x27b65a2f makeImagePlus + 930
4 ImageIO 0x27b65271 CGImageSourceCreateImageAtIndex + 160
5 UIKit 0x2a1e0bf3 _UIImageRefFromData + 262
6 UIKit 0x2a32d191 -[UIImage(UIImagePrivate) _initWithData:preserveScale:cache:] + 76
7 UIKit 0x2a1e0ae5 -[UIImage initWithData:] + 28
8 UIKit 0x2a2a36af -[UIImage initWithData:scale:] + 22
9 UIKit 0x2a32b721 +[UIImage imageWithData:scale:] + 56
EXC_BAD_ACCESS KERN_INVALID_ADDRESS at 0x00000000
Thread : Crashed: com.apple.main-thread
0 CoreFoundation 0x25bca41c CFArrayGetCount + 23
1 ImageIO 0x26c3898b getImagePlus + 118
2 ImageIO 0x26c3898b getImagePlus + 118
3 ImageIO 0x26c38433 makeImagePlus + 46
4 ImageIO 0x26c37fed CGImageSourceCreateImageAtIndex + 160
5 UIKit 0x292954c3 _UIImageRefFromData + 282
6 UIKit 0x293e1ad9 -[UIImage(UIImagePrivate) _initWithData:preserveScale:cache:] + 76
7 UIKit 0x292953a5 -[UIImage initWithData:] + 28
8 UIKit 0x29357ee7 -[UIImage initWithData:scale:] + 22
9 UIKit 0x293e0081 +[UIImage imageWithData:scale:] + 56
EXC_BAD_ACCESS UNKNOWN at 0x0000000104f44000
Thread : Crashed: com.apple.main-thread
0 libsystem_platform.dylib 0x0000000194795390 _platform_memmove + 320
1 libsystem_c.dylib 0x0000000194690424 __memcpy_chk + 32
2 libsystem_c.dylib 0x0000000194690424 __memcpy_chk + 32
3 ImageIO 0x0000000184a3172c _CGImageSourceBindToPlugin + 316
4 ImageIO 0x0000000184a31574 CGImageSourceGetCount + 112
5 UIKit 0x000000018816d46c _UIImageRefFromData + 276
6 UIKit 0x00000001882d1c20 -[UIImage(UIImagePrivate) _initWithData:preserveScale:cache:] + 112
7 UIKit 0x000000018823e21c -[UIImage initWithData:scale:] + 32
8 UIKit 0x00000001882cffa4 +[UIImage imageWithData:scale:] + 72
我看不出我的代码会对此有什么影响,但我尝试向此方法发送nil,它只返回nil。损坏的NSData会导致这种崩溃吗?此方法是否保留NSData?会不会是因为NSData在处理这行的时候被释放了?我不这么认为,因为它是同步的,对吧?
除此之外,我不能重现这个bug,但因为我们有一个庞大的用户基础,所以它经常发生。我还注意到,在iOS 8上,这种情况发生的可能性高达99%。
任何帮助都将不胜感激。
发布于 2015-06-27 05:48:43
你使用的库是AFNetwork还是Hanekee?由于ios8 UIImage imageWithData的原因,我刚刚向这两个库都提交了一个拉取请求。带数据的UIImage似乎不是线程安全的,这意味着从不同的线程同时调用它会崩溃……复制它的一种方法是测试以下代码:
let data = NSData(contentsOfURL: NSURL(string: "https://encrypted-tbn3.gstatic.com/images?q=tbn:ANd9GcTf4P0V2TrszykwPguyeulcSt4vwQPcvvWKKq_RePhUUVFoHevG9lw8GVcw")!)
var test: Array<UIImage> = []
let lock = NSLock()
for i in 0...10000 {
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), { () -> Void in
NSLog("Processing \(i)")
let a = UIImage(data:data!)
NSLog("Processed \(i)")
lock.lock()
test.append(a!)
test.removeLast()
lock.unlock()
})
所以一定要同步数据(UIImage:data!)或者UIImage imageWithData:数据调用,以避免同时调用。
拉取请求:
哈内克:https://github.com/Haneke/HanekeSwift/pull/207
AFNetwork:https://github.com/AFNetworking/AFNetworking/pull/2815
https://stackoverflow.com/questions/28905925
复制相似问题