我正在使用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];
}
答案 0 :(得分:0)
运行本地捆绑图像和网络图像,似乎任何重大泄漏都消失了。这与iOS7和Xcode 5。