大佬教程收集整理的这篇文章主要介绍了是什么导致块不能在ARC下保留引用的Objective-C对象?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
这通常发生在对象已被释放并且另一个对象现在与解除分配的对象位于同一地址时.
这是我的代码(我的应用程序中唯一一个我调用CGImage方法的地方):
@implementation UIImageView (MyApp) - (void) setImageWithObject:(id)object { NSURLrequest *imagerequest = [NSURLrequest requestWithURL:[object URL]]; __typeof__(self) __weak weakSelf = self; [self setImageWithURLrequest:imagerequest placeholderImage:nil success:^(NSURLrequest *request,NShttpURLResponse *response,UIImage *imagE) { dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT,0),^{ CGImageRef imageRef = [image CGImage]; CGRect rect = CGRectMake(0.f,0.f,CGImageGetWidth(imageRef),CGImageGetHeight(imageRef)); CGContextRef bitmapContext = CGBitmapContextCreate(NULL,(size_t)roundf(CGRectGetWidth(rect)),(size_t)roundf(CGRectGetHeight(rect)),CGImageGetBitsPerComponent(imageRef),CGImageGetBytesPerRow(imageRef),CGImageGetColorSpace(imageRef),CGImageGetBitmapInfo(imageRef)); UIImage *decompressedImage = image; if (bitmapContext) { CGContextDrawImage(bitmapContext,rect,imageRef); CGImageRef decompressedImageRef = CGBitmapContextCreateImage(bitmapContext); decompressedImage = [UIImage imageWithCGImage:decompressedImageRef scale:image.scale orientation:image.imageOrientation]; CGImageRelease(decompressedImageRef); CGContextRelease(bitmapContext); } dispatch_async(dispatch_get_main_queue(),^{ weakSelf.image = decompressedImage; }); }); } failure:^(NSURLrequest *request,NSError *error) { NSLog(@"%@",error); }]; } @end
我假设图像对象应该由块自动保留(我正在使用ARC),以便在使用默认优先级队列执行使用它的代码之前,不能释放图像对象.崩溃似乎意味着它没有被保留.
我的假设是错的还是我错过了别的什么?
那你在哪里:
CGImageRef imageRef = [image CGImage];
我认为你需要在块中明确地保留它然后明确地释放它,因此ARC不会释放图像引用.
所以:
CGImageRef imageRef = CGImageRetain([image CGImage]); ... CGImageRelease(imageRef);
以上是大佬教程为你收集整理的是什么导致块不能在ARC下保留引用的Objective-C对象?全部内容,希望文章能够帮你解决是什么导致块不能在ARC下保留引用的Objective-C对象?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。