iOS sd_webImage加載大圖片時(shí)導(dǎo)致內(nèi)存飆升解決方法

SDWebImage大家肯定都恨熟悉了,國(guó)內(nèi)外太多的App使用其進(jìn)行圖片加載。

但是最近在使用過(guò)程中發(fā)現(xiàn),我用SDWebImage加載多個(gè)圖片,類似微博動(dòng)態(tài)那種,在加載的過(guò)程中。我發(fā)現(xiàn)當(dāng)圖片分辨率比較大的時(shí)候(不是圖片大),加載幾張圖片就崩潰了。

網(wǎng)上說(shuō)可以每次加載圖片清空memcache,但是效果并不好。
  [[SDImageCache sharedImageCache] setValue:nil forKey:@"memCache"];

這地方采用的方法是:

第一步:在 UIImage+MultiFormat這個(gè)類里面添加如下壓縮方法

 +(UIImage *)compressImageWith:(UIImage *)image  {
    float imageWidth = image.size.width;
    float imageHeight = image.size.height;
    float width = 320;
    float height = image.size.height/(image.size.width/width);
    float widthScale = imageWidth /width;
    float heightScale = imageHeight /height;
    // 創(chuàng)建一個(gè)bitmap的context
    // 并把它設(shè)置成為當(dāng)前正在使用的context
    UIGraphicsBeginImageContext(CGSizeMake(width, height));
      
    if (widthScale > heightScale) {
          [image drawInRect:CGRectMake(0, 0, imageWidth /heightScale , height)];
     }else {
          [image drawInRect:CGRectMake(0, 0, width , imageHeight /widthScale)];
     }

     // 從當(dāng)前context中創(chuàng)建一個(gè)改變大小后的圖片

     UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();
      // 使當(dāng)前的context出堆棧
     UIGraphicsEndImageContext();
      return newImage;
}

第二步: 在下面這個(gè)方法里調(diào)用壓縮方法

+ (nullable UIImage *)sd_imageWithData:(nullable NSData *)data {
    if (!data) {
        return nil;
     }

    UIImage *image;
    SDImageFormat imageFormat = [NSData sd_imageFormatForImageData:data];

    if (imageFormat == SDImageFormatGIF) {
           image = [UIImage sd_animatedGIFWithData:data];
    }
    #ifdef SD_WEBP
    else if (imageFormat == SDImageFormatWebP){
          image = [UIImage sd_imageWithWebPData:data];
    }
    #endif
    else {
          image = [[UIImage alloc] initWithData:data];
          image = [[UIImage alloc] initWithData:data];
          if (data.length/1024 > 90) {
                image = [self compressImageWith:image];
          }
          UIImageOrientation orientation = [self sd_imageOrientationFromImageData:data];
          if (orientation != UIImageOrientationUp) {
                image = [UIImage imageWithCGImage:image.CGImage scale:image.scale orientation:orientation];
           }
      }
      return image;
}

第三步:

就是在SDWebImageDownloaderOperation的connectionDidFinishLoading方法里面的:

UIImage *image = [UIImage sd_imageWithData:self.imageData];

NSString *key = [[SDWebImageManager sharedManager] cacheKeyForURL:self.request.URL];

image = [self scaledImageForKey:key image:image];

NSData *data = UIImageJPEGRepresentation(image, 1);

self.imageData = [NSMutableData dataWithData:data];
最后;再配合 [[SDImageCache sharedImageCache] setValue:nil forKey:@"memCache"];(圖片加載后使用)大功告成,親測(cè)內(nèi)存基本變化不大,自動(dòng)釋放也來(lái)得及
waring!!!注意:這個(gè)方法慎用,否則的話你所有的圖片都會(huì)被壓縮以后展示的時(shí)候就不清晰了.這個(gè)方法的原理是通過(guò)壓縮圖片質(zhì)量實(shí)現(xiàn)的.但是本人認(rèn)為最好不要采用這個(gè)方法.除非你自己在需要加載小圖的地方加標(biāo)志,來(lái)告訴sd,這個(gè)時(shí)候就需要修改sd了大家可以按這個(gè)思路進(jìn)行,但是修改起來(lái)可能麻煩.

第二種方案有一個(gè)比較好的處理方法,可以考慮一下,當(dāng)年寫(xiě)這個(gè)的時(shí)候腦子沒(méi)轉(zhuǎn)過(guò)來(lái)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容