进击的SDWebImage(一)

前言

网上有很多SDWebImage的源码分析贴,现想自己开一篇写上自己学习的点点滴滴,希望激励自己的技术能更进一步.

开篇

做为第一篇当然是弄清楚这个工具要做的是什么,那对于我们程序员来说就是一种面对过程的理解方法,那么这个第一篇就用面对过程的方法写出自己的理解.

不多说了直接上图:

//1.内存中去寻找有没有这个图
        //如果有就直接显示出来
        //2.内存中没有这个图就到磁盘中去找
                //磁盘中找到了就缓存到内存当中,并显示出来
                //3.都没找到去网络上下载
                      //如果下载成功,保存到内存和磁盘当中
                      //显示图片

先准备一点东西,写一个继承自NSCache的自己的内存缓存单例类:

+(LYCache*)sharedCache{
    static dispatch_once_t once;
    static id instance;
    dispatch_once(&once, ^{
        instance = [self new];
    });
    return instance;
}

另一个是MD5加密的方法,这个方法可以直接SDWebImage拿过来(估计还可以拿很多的工具0.0),存储图片的名字都是通过MD5加密之后存起来的,可能是这样看上去会比较舒服一点:

- (NSString *)cachedFileNameForKey:(NSString *)key {
    const char *str = [key UTF8String];
    if (str == NULL) {
        str = "";
    }
    unsigned char r[CC_MD5_DIGEST_LENGTH];
    CC_MD5(str, (CC_LONG)strlen(str), r);
    NSString *filename = [NSString stringWithFormat:@"%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%@",
                          r[0], r[1], r[2], r[3], r[4], r[5], r[6], r[7], r[8], r[9], r[10],
                          r[11], r[12], r[13], r[14], r[15], [[key pathExtension] isEqualToString:@""] ? @"" : [NSString stringWithFormat:@".%@", [key pathExtension]]];
    
    return filename;
}

下面就可以去填满上面的空缺了:

    self.imageUrl = @"http://img12.360buyimg.com/n0/jfs/t289/30/1219748821/432500/b67cb240/543394bcN0cd63cef.jpg";
    NSString *key = [self cachedFileNameForKey:self.imageUrl];
    
    //1.内存中去寻找有没有这个图,这个查询应该是异步的,后面封装的时候再处理
    LYCache *cache = [LYCache sharedCache];
    UIImage *image =  [cache objectForKey:key];
    if (image) {
        self.imageView.image = image;
    }else{
        //2.内存中没有这个图就到磁盘中去找
        //磁盘中找到了缓存到内存当中
        NSFileManager *fileManager = [NSFileManager defaultManager];
        NSArray*path =NSSearchPathForDirectoriesInDomains(NSCachesDirectory,NSUserDomainMask,YES);
        
        NSString*documentPath = [path lastObject];
        NSString *cachePath = [NSString stringWithFormat:@"%@/myCache",documentPath];
        cachePath =  [cachePath stringByAppendingPathComponent:[NSString stringWithFormat:@"%@",key]];
        BOOL isOne =  [fileManager fileExistsAtPath:cachePath];
        if (isOne) {
            
            //保存到内存当中
            LYCache *cache = [LYCache sharedCache];
            [cache setObject:image forKey:key];
            
            UIImage *image = [UIImage imageWithData:[NSData dataWithContentsOfFile:cachePath]];
            self.imageView.image = image;
        }else{
            //3.都没找到去网络上下载
            //开启下载
            NSURLSessionConfiguration *sessionConfig =[NSURLSessionConfiguration defaultSessionConfiguration];
            
            NSURLSession *session =[NSURLSession sessionWithConfiguration:sessionConfig
                                                                 delegate:self
                                                            delegateQueue:nil];
            
            NSURLSessionDownloadTask *getImageTask = [session downloadTaskWithURL:[NSURL URLWithString:self.imageUrl]];
            
            [getImageTask resume];
        }
    }

下载的代理方法:

-(void)URLSession:(NSURLSession *)session downloadTask:(NSURLSessionDownloadTask *)downloadTask didFinishDownloadingToURL:(NSURL *)location{
    
    NSData *imageData = [NSData dataWithContentsOfURL:location];
    if (imageData) {
        UIImage *downloadImage = [UIImage imageWithData:imageData];
        
        //保存到内存当中
        LYCache *cache = [LYCache sharedCache];
        NSString *key = [self cachedFileNameForKey:self.imageUrl];
        [cache setObject:downloadImage forKey:key];
        
        //保存到磁盘当中
        NSFileManager *fileManager = [NSFileManager defaultManager];
        NSArray*path =NSSearchPathForDirectoriesInDomains(NSCachesDirectory,NSUserDomainMask,YES);
        
        NSString*documentPath = [path lastObject];
        NSString *cachePath = [NSString stringWithFormat:@"%@/myCache",documentPath];
        //如果没有这文件夹就创建文件夹
        if (![fileManager fileExistsAtPath:cachePath]) {
            [fileManager createDirectoryAtPath:cachePath  withIntermediateDirectories:YES attributes:nil error:nil];
        }
        
        cachePath =  [cachePath stringByAppendingPathComponent:[NSString stringWithFormat:@"%@",key]];
        
        BOOL isSuccess = [fileManager createFileAtPath:cachePath contents:imageData attributes:nil];
        if (isSuccess) {
            NSLog(@"存储成功");
            dispatch_async(dispatch_get_main_queue(), ^{
                self.imageView.image = downloadImage;
            });
        }else{
            NSLog(@"存储失败");
        }
    }
}

总结:

自己一写才知道要很完美估计是不能的,但是一边看SDWebImage的源码才看出自己的很多的不足,后面的章节要开始封装了,还是对照的SDWebImage来一点点写下去,希望能从中学到更多的东西(面对对象的思想,架构的思想,一些奇特的用法等等),也希望大家多给意见.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容