翠鸟奇怪的RAM行为

时间:2017-06-06 03:58:29

标签: ios swift caching ram kingfisher

我使用Kingfisher将图像加载到卡片视图(UIView)中,就像在火种中一样,我将翠鸟设置为将图像缓存到磁盘,但在分页过程中,内存消耗显着增加从39兆字节到247并且过了一会儿又变成39,但问题是当内存被释放时,在第二个UI的应用程序中减速(我认为这被主线程阻止)。此问题与this one.类似,我该如何解决?

我在AppDelegate

didFinishLaunchingWithOptions设置了翠鸟的设置
fileprivate func setupKingfisherSettings() {
        let megabytes: UInt = 300
        ImageCache.default.maxDiskCacheSize = megabytes * 1024 * 1024
        ImageCache.default.maxMemoryCost = 1
    }

代码片段。当我删除此代码时,没有发生此问题。

private func downloadImages(_ card: CardModel) {
    if let placeAvatarURLString = card.photoURLsProperties.placePhotoURLs.first {
        if let placeAvatarURL = URL(string: placeAvatarURLString) {
            venueImageView.kf.indicatorType = .activity
            venueImageView.kf.setImage(with: placeAvatarURL)
        } else {
            venueImageView.image = UIImage(named: "CardDefaultImage")
        }
    } else if let eventLogoURLPath = card.photoURLsProperties.placeLogoURLs.first {
        if let url = URL(string: eventLogoURLPath) {
            venueImageView.kf.indicatorType = .activity
            venueImageView.kf.setImage(with: url)
        } else {
            venueImageView.image = UIImage(named: "CardDefaultImage")
        }
    } else {
        venueImageView.image = UIImage(named: "CardDefaultImage")
    }
}

enter image description here

更新::发生这种情况时我发现了一个规律性。当ImageCache提取大于5兆字节的图像时,会发生内存跳转。我在这个方法diskImage中发现它使用debugPrint,如果图像等于或大于5兆字节,那么有一个跳转,如果是4兆字节,那么一切都很好。

我在iPhone 7上测试了超过74千兆字节的可用内存。

 func diskImage(forComputedKey key: String, serializer: CacheSerializer, options: KingfisherOptionsInfo) -> Image? {
        if let data = diskImageData(forComputedKey: key) {
            debugPrint("ImageCache data.count", data.count / 1024 / 1024)
            return serializer.image(with: data, options: options)
        } else {
            return nil
        }
    }

1 个答案:

答案 0 :(得分:1)

目前我解决了我的问题,我编写了自定义CacheSerializer,并将图像压缩到3兆字节。但我对其他答案感兴趣,如何解决这个问题。

import Kingfisher

struct AppNameKingfisherCacheSerializer: CacheSerializer {

    func data(with image: Image, original: Data?) -> Data? {
        return image.compressToData(3)
    }

    func image(with data: Data, options: KingfisherOptionsInfo?) -> Image? {
        return UIImage(data: data)
    }

}