CGContextDrawImage内存未释放

时间:2012-12-12 08:20:19

标签: ios memory cgcontext

我正在使用PhotoScrollerNetwork project为项目中的视图提供单个高分辨率图像并自动平铺它,因此可以正确管理内存。它使用这段代码将完整的高分辨率图像绘制到内存中,以便可以从中计算出图块。

-(void)drawImage:(CGImageRef)image {
       madvise(ims[0].map.addr, ims[0].map.mappedSize - ims[0].map.emptyTileRowSize, MADV_SEQUENTIAL);

       unsigned char *addr = ims[0].map.addr + ims[0].map.col0offset + ims[0].map.row0offset * ims[0].map.bytesPerRow;
       CGContextRef context = CGBitmapContextCreate(addr, ims[0].map.width, ims[0].map.height, bitsPerComponent, ims[0].map.bytesPerRow, colorSpace, kCGImageAlphaNoneSkipFirst | kCGBitmapByteOrder32Little);
       assert(context);
       CGContextSetBlendMode(context, kCGBlendModeCopy); // Apple uses this in QA1708
       CGRect rect = CGRectMake(0, 0, ims[0].map.width, ims[0].map.height);
       CGContextDrawImage(context, rect, image);
       CGContextRelease(context);

       madvise(ims[0].map.addr, ims[0].map.mappedSize - ims[0].map.emptyTileRowSize, MADV_FREE);
 }

在类的dealloc方法中,ims被释放('free(ims)'),因此应该正确处理。但是,如果我重复创建一个新视图(因此调用drawImage),我的记忆就会被填满。我发现如果我评论CGContextDrawImage(context, rect, image);,内存是可以的,所以我认为内存中保留了一些东西,但是我无法得到什么...总是调用dealloc方法,所以这不是问题所在。 / p>

编辑: 我的图像也正确发布,这是完整的流程:

- (void)myFunc {
        CFDictionaryRef options = [self createOptions];
        CGImageRef image = CGImageSourceCreateImageAtIndex(imageSourcRef, 0, options);
        CFRelease(options);
        CFRelease(imageSourcRef);
        if (image) {
            [self decodeImage:image];
            CGImageRelease(image);
        }
}

- (void)decodeImage:(CGImageRef)image {
    assert(decoder == cgimageDecoder);

    size_t width = CGImageGetWidth(image);
    size_t height = CGImageGetHeight(image);

#if LEVELS_INIT == 0
    zoomLevels = [self zoomLevelsForSize:CGSizeMake(width, height)];
    ims = calloc(zoomLevels, sizeof(imageMemory));
#endif

    [self mapMemoryForIndex:0 width:width height:height];

    [self drawImage:image];
    [self createLevelsAndTile];
}

1 个答案:

答案 0 :(得分:0)

运行本地捆绑图像和网络图像,似乎任何重大泄漏都消失了。这与iOS7和Xcode 5。