0

我有以下方法在文档目录中获取一个 pdf 文件并从中创建一个缩略图。如注释中所示,此方法在两个地方泄漏内存。由于我使用的是 ARC,我不确定它为什么会泄漏内存。我该如何解决这个问题。

  + (UIImage*)createPdfThumbnail:(NSString*)pdfFilePath {


        NSURL *targetURL = [NSURL fileURLWithPath:pdfFilePath];
        CGPDFDocumentRef pdf = CGPDFDocumentCreateWithURL((__bridge CFURLRef)targetURL);  // 3.0% of memory leak

        CGPDFPageRef page = CGPDFDocumentGetPage(pdf, 1);//for the first  page
        CGRect aRect = CGPDFPageGetBoxRect(page, kCGPDFCropBox);
        UIGraphicsBeginImageContext(aRect.size);
        CGContextRef context = UIGraphicsGetCurrentContext();

        CGContextSaveGState(context);
        CGContextTranslateCTM(context, 0.0, aRect.size.height);
        CGContextScaleCTM(context, 1.0, -1.0);
        CGContextTranslateCTM(context, -(aRect.origin.x), -(aRect.origin.y));

        CGContextSetGrayFillColor(context, 1.0, 1.0);
        CGContextFillRect(context, aRect);

        CGAffineTransform pdfTransform = CGPDFPageGetDrawingTransform(page, kCGPDFCropBox, aRect, 0, false);
        CGContextConcatCTM(context, pdfTransform);
        CGContextDrawPDFPage(context, page);

        UIImage *thumbnail = UIGraphicsGetImageFromCurrentImageContext(); // 97% of memory leak
        CGContextRestoreGState(context);
        UIGraphicsEndImageContext();
        CGPDFDocumentRelease(pdf);
        return thumbnail;

}

编辑

-(void)fromJSON:(NSDictionary *)JSON{
    [super fromJSON:JSON];
    self.path = JSON[@"path"];
    //Create and save thumbnail
    if (self.parentSpecSheet != nil){
        @autoreleasepool {
            UIImage* thumbnail = [Utilities createPdfThumbnail:self.path];
            Photo* thumbnailPhoto = [Photo addObject];
            [thumbnailPhoto setDelta:@(0)];
            [thumbnailPhoto setImage:thumbnail];
            [thumbnailPhoto.file setDelta:@(0)];
            self.parentSpecSheet.thumbnail = thumbnailPhoto;
        }
    }
}
4

1 回答 1

0

两个想法:

  1. 当我在 iOS5 中测试您的代码时,我遇到了严重的泄漏CGContextDrawPDFPage(如果您搜索"CGContextDrawPDFPage leak",您会看到大量对这个问题排列的引用)。这似乎是一个已知问题。

    不过,我从上面的代码中看不到 iOS 6 中有明显的泄漏。

  2. 如果您仍然在 iOS 6 中看到此泄漏,那么我怀疑问题不在于上述代码。您是否报告了任何其他泄漏?我还建议您确认拥有它的对象thumbnail本身已成功释放(例如,其dealloc方法中的日志/断点)。

    不幸的是,当您查看泄漏工具时,它报告的是泄漏对象的实例化位置,而不是泄漏发生的位置。您可能想确认 this 的所有者thumbnail以某种方式没有维护对它的强引用(例如,所有者本身具有保留周期或类似的东西)。

于 2013-07-17T07:19:45.353 回答