一個(gè)簡(jiǎn)單的網(wǎng)絡(luò)Image緩存類

該類的主要作用是员淫,下載以及緩存圖片,用了很少的代碼板乙,很實(shí)用砸脊。

代碼如下

import Foundation
import UIKit

public class YHImageLoader {
    
    var cache = NSCache<NSString, NSData>()
    
    /// 單例
    static let sharedLoader = YHImageLoader()
    
    /// 下載圖片
    ///
    /// - Parameters:
    ///   - urlString: 圖片url
    ///   - completionHandler: 圖片下載完成后的回調(diào)
    public func imageForUrl(urlString: String, completionHandler: @escaping(_ image: UIImage?, _ url: String) -> ()) {
        //子線程中下載具篇,并且可以在后臺(tái)下載
        DispatchQueue.global(qos: DispatchQoS.QoSClass.background).async {
            var data: NSData?
            //從緩存中讀取
            if let dataCache = self.cache.object(forKey: urlString as NSString) {
                data = dataCache as NSData
            }else {
                //緩存中沒(méi)有,假如url是一個(gè)文件路徑
                if (URL(string: urlString) != nil) {
                    data = NSData(contentsOf: URL(string: urlString)!)
                    if data != nil {
                        self.cache.setObject(data!, forKey: urlString as NSString)
                    }
                }else {
                    //假如路徑時(shí)錯(cuò)誤的凌埂,返回
                    return
                }
            }
            //數(shù)據(jù)是存在的
            if let goodData = data {
                let image = UIImage(data: goodData as Data)
                DispatchQueue.main.async{
                    completionHandler(image, urlString)
                }
                return
            }
            //數(shù)據(jù)不存在驱显,下載
            URLSession.shared.dataTask(with: URL(string: urlString)!, completionHandler: { (data, response, error) in
                if (error != nil) {
                    completionHandler(nil, urlString)
                    return
                }
                if data != nil {
                    let image = UIImage(data: data!)
                    self.cache.setObject(data! as NSData, forKey: urlString as NSString)
                    DispatchQueue.main.async {
                        completionHandler(image, urlString)
                    }
                    return
                }
            }).resume()
        }
    }
}

使用

import UIKit

class ViewController: UIViewController {

    var image: UIImageView!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        image = UIImageView(frame: view.frame)
        view.addSubview(image)
        YHImageLoader.sharedLoader.imageForUrl(urlString: "https://ss1.baidu.com/6ONXsjip0QIZ8tyhnq/it/u=1427822428,3741610415&fm=173&s=CCB707D069FB3B86C28DD507030080C9&w=640&h=353&img.JPG") { [weak self] (image, url) in
            if let weakSelf = self {
                weakSelf.image.image = image
            }
        }
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }
}

邏輯如下

  • YHImageLoader是一個(gè)單例類
  • cache屬性用于緩存下載的圖片
  • 下載的邏輯就是,先從cache中讀取緩存瞳抓,如果緩存沒(méi)有埃疫,再判斷url是不是文件的路勁,如果是孩哑,就讀取文件栓霜。如果不是,則下載横蜒,下載完畢后保存到cache中胳蛮。
  • 可以根據(jù)需要,將下載的圖片保存到本地丛晌,然后讀取的時(shí)候仅炊,多加一步讀取本地是否有該圖片。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末澎蛛,一起剝皮案震驚了整個(gè)濱河市茂洒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌瓶竭,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件渠羞,死亡現(xiàn)場(chǎng)離奇詭異斤贰,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)次询,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)荧恍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人屯吊,你說(shuō)我怎么就攤上這事送巡。” “怎么了盒卸?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵骗爆,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蔽介,道長(zhǎng)摘投,這世上最難降的妖魔是什么煮寡? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮犀呼,結(jié)果婚禮上幸撕,老公的妹妹穿的比我還像新娘。我一直安慰自己外臂,他們只是感情好坐儿,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著宋光,像睡著了一般貌矿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上跃须,一...
    開(kāi)封第一講書(shū)人閱讀 51,521評(píng)論 1 304
  • 那天站叼,我揣著相機(jī)與錄音,去河邊找鬼菇民。 笑死尽楔,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的第练。 我是一名探鬼主播阔馋,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼娇掏!你這毒婦竟也來(lái)了呕寝?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤婴梧,失蹤者是張志新(化名)和其女友劉穎下梢,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體塞蹭,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡孽江,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了番电。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片岗屏。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖漱办,靈堂內(nèi)的尸體忽然破棺而出这刷,到底是詐尸還是另有隱情,我是刑警寧澤娩井,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布暇屋,位于F島的核電站,受9級(jí)特大地震影響撞牢,放射性物質(zhì)發(fā)生泄漏率碾。R本人自食惡果不足惜叔营,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望所宰。 院中可真熱鬧绒尊,春花似錦、人聲如沸仔粥。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)躯泰。三九已至谭羔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間麦向,已是汗流浹背瘟裸。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留诵竭,地道東北人话告。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像卵慰,于是被迫代替她去往敵國(guó)和親沙郭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,133評(píng)論 25 707
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理裳朋,服務(wù)發(fā)現(xiàn)病线,斷路器,智...
    卡卡羅2017閱讀 134,657評(píng)論 18 139
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)鲤嫡、插件送挑、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,103評(píng)論 4 62
  • 五一去的寧波,目的地是普陀山暖眼。寧波第一給我的感覺(jué)是空氣新鮮干凈让虐,溫度低了幾度。到寧波已經(jīng)是晚上罢荡,本地朋友帶去吃的海...
    修味閱讀 440評(píng)論 0 0
  • 十七歲的我是什么樣子的区赵? 十七歲的時(shí)候,我念高二浪南。 以全校前幾名的成績(jī)進(jìn)入高中笼才,后來(lái)勉強(qiáng)游走在重點(diǎn)班中間水平還樂(lè)哉...
    言昭昭閱讀 439評(píng)論 0 0