前言
什么是觀察者模式赫舒?我們先打個(gè)比方悍及,這就像你訂報(bào)紙。比如你想知道美國(guó)最近放生了些新聞接癌,你可能會(huì)訂閱一份美國(guó)周刊心赶,然后一旦美國(guó)有了新的故事,美 國(guó)周刊就發(fā)一刊缺猛,并郵寄給你缨叫,當(dāng)你收到這份報(bào)刊,然后你就能夠了解美國(guó)最新的動(dòng)態(tài)荔燎。其實(shí)這就是觀察者模式耻姥,A對(duì)B的變化感興趣,就注冊(cè)為B的觀察者有咨,當(dāng)B 發(fā)生變化時(shí)通知A琐簇,告知B發(fā)生了變化。這是一種非常典型的觀察者的用法座享,我把這種使用方法叫做經(jīng)典觀察者模式婉商。當(dāng)然與之相對(duì)的還有另外一種觀察者模式—— 廣義觀察者模式。
從經(jīng)典的角度看征讲,觀察者模式是一種通知變化的模式据某,一般認(rèn)為只在對(duì)象發(fā)生變化感興趣的場(chǎng)合有用。主題對(duì)象知道有觀察者存在诗箍,設(shè)置會(huì)維護(hù)觀察者的一個(gè) 隊(duì)列癣籽;而從廣義的角度看挽唉,觀察者模式是中傳遞變化數(shù)據(jù)的模式,需要查看對(duì)象屬性時(shí)就會(huì)使用的一種模式筷狼,主題對(duì)象不知道觀察者的存在瓶籽,更像是圍觀者。需要知 道主題對(duì)象的狀態(tài)埂材,所以即使在主題對(duì)象沒(méi)有發(fā)生改變的時(shí)候塑顺,觀察者也可能會(huì)去訪問(wèn)主題對(duì)象。換句話說(shuō)廣義觀察者模式俏险,是在不同的對(duì)象之間傳遞數(shù)據(jù)的一種模 式严拒。
觀察者模式應(yīng)當(dāng)是在面向?qū)ο缶幊讨斜淮笠?guī)模使用的設(shè)計(jì)模式之一。從方法論的角度出發(fā)竖独,傳統(tǒng)的認(rèn)知論認(rèn)為裤唠,世界是由對(duì)象組成的,我們通過(guò)不停的觀察和 了解就能夠了解對(duì)象的本質(zhì)莹痢。整個(gè)人類的認(rèn)知模型就是建立在“觀察”這種行為之上的种蘸。我們通過(guò)不停與世界中的其他對(duì)象交互,并觀察之來(lái)了解這個(gè)世界竞膳。同樣航瞭, 在程序的世界中,我們構(gòu)建的每一個(gè)實(shí)例坦辟,也是通過(guò)不停的與其他對(duì)象交互(查看其他對(duì)象的狀態(tài)刊侯,或者改變其他對(duì)象的狀態(tài)),并通過(guò)觀察其他實(shí)例的變化并作 出響應(yīng)长窄,以來(lái)完成功能滔吠。這也就是,為什么會(huì)把觀察模式單獨(dú)提出來(lái)挠日,做一個(gè)專門(mén)的剖析的原因——在我看來(lái)他是很多其他設(shè)計(jì)模式的基礎(chǔ)模式疮绷,并且是編程中極其 重要的一種設(shè)計(jì)模式。
經(jīng)典觀察者模式
經(jīng)典觀察者模式被認(rèn)為是對(duì)象的行為模式嚣潜,又叫發(fā)布-訂閱(Publish/Subscribe)模式冬骚、模型-視圖(Model/View)模式、源 -監(jiān)聽(tīng)器(Source/Listener)模式或從屬者(Dependents)模式懂算。經(jīng)典觀察者模式定義了一種一對(duì)多的依賴關(guān)系只冻,讓多個(gè)觀察者對(duì)象同 時(shí)監(jiān)聽(tīng)某一個(gè)主題對(duì)象。這個(gè)主題對(duì)象在狀態(tài)上發(fā)生變化時(shí)计技,會(huì)通知所有觀察者對(duì)象喜德,使它們能夠自動(dòng)更新自己或者做出相應(yīng)的一些動(dòng)作。在文章一開(kāi)始舉的例子就 是典型觀察者模式的應(yīng)用垮媒。
而在IOS開(kāi)發(fā)中我們可能會(huì)接觸到的經(jīng)典觀察者模式的實(shí)現(xiàn)方式舍悯,有這么幾種:NSNotificationCenter航棱、KVO、Delegate等
感知通知方式
在經(jīng)典觀察者模式中萌衬,因?yàn)橛^察者感知到主題對(duì)象變化方式的不同饮醇,又分為推模型和拉模型兩種方式。
推模型
主題對(duì)象向觀察者推送主題的詳細(xì)信息秕豫,不管觀察者是否需要朴艰,推送的信息通常是主題對(duì)象的全部或者部分?jǐn)?shù)據(jù)。推模型實(shí)現(xiàn)了觀察者和主題對(duì)象的解耦混移,兩 者之間沒(méi)有過(guò)度的依賴關(guān)系祠墅。但是推模型每次都會(huì)以廣播的方式,向所有觀察者發(fā)送通知歌径。所有觀察者被動(dòng)的接受通知饵隙。當(dāng)通知的內(nèi)容過(guò)多時(shí),多個(gè)觀察者同時(shí)接 收沮脖,可能會(huì)對(duì)網(wǎng)絡(luò)、內(nèi)存(有些時(shí)候還會(huì)涉及IO)有較大影響芯急。
在IOS中典型的推模型實(shí)現(xiàn)方式為NSNotificationCenter和KVO勺届。
NSNotificationCenter
NSnotificationCenter是一種典型的有調(diào)度中心的觀察者模式實(shí)現(xiàn)方式。以NSNotificationCenter為中心娶耍,觀察者往 Center中注冊(cè)對(duì)某個(gè)主題對(duì)象的變化感興趣免姿,主題對(duì)象通過(guò)NSNotificationCenter進(jìn)行變化廣播。這種模型就是文章開(kāi)始發(fā)布訂閱報(bào)紙 在OC中的一種類似實(shí)現(xiàn)榕酒。所有的觀察和監(jiān)聽(tīng)行為都向同一個(gè)中心注冊(cè)胚膊,所有對(duì)象的變化也都通過(guò)同一個(gè)中心向外廣播。
NSNotificationCenter就像一個(gè)樞紐一樣想鹰,處在整個(gè)觀察者模式的核心位置紊婉,調(diào)度著消息在觀察者和監(jiān)聽(tīng)者之間傳遞。