首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Crash on + (UIImage *)imageWithData:(NSData *)data scale:(CGFloat)scale on iOS 8| EXC_BAD_ACCESS未知或KERNEL_INVALID_ADDRESS

Crash on + (UIImage *)imageWithData:(NSData *)data scale:(CGFloat)scale on iOS 8| EXC_BAD_ACCESS未知或KERNEL_INVALID_ADDRESS
EN

Stack Overflow用户
提问于 2015-03-07 03:09:30
回答 1查看 1.3K关注 0票数 4

我的应用程序的前两个崩溃发生在下面的方法上:

代码语言:javascript
运行
复制
+ (UIImage *)imageWithData:(NSData *)data scale:(CGFloat)scale

到目前为止,它已经发生了2000多次,根据崩溃报告,它以略有不同的方式表现出来:

代码语言:javascript
运行
复制
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%。

任何帮助都将不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2015-06-27 05:48:43

你使用的库是AFNetwork还是Hanekee?由于ios8 UIImage imageWithData的原因,我刚刚向这两个库都提交了一个拉取请求。带数据的UIImage似乎不是线程安全的,这意味着从不同的线程同时调用它会崩溃……复制它的一种方法是测试以下代码:

代码语言:javascript
运行
复制
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

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28905925

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档