iOS-通知知識點

如果在一個類中想要執(zhí)行另一個類中的方法可以使用通知1.創(chuàng)建一個通知對象:使用notificationWithName:object: 或者 notificationWithName:object:userInfo: NSNotification* notification = [NSNotification notificationWithName:kImageNotificationLoadFailed(connection.imageURL) object:self userInfo:[NSDictionary dictionaryWithObjectsAndKeys:error,@"error",connection.imageURL,@"imageURL",nil]];
這里需要注意的是,創(chuàng)建自己的通知并不是必須的署拟。而是在創(chuàng)建自己的通知之前,采用NSNotificationCenter類的方法 postNotificationName:object: 和 postNotificationName:object:userInfo:更加便利的發(fā)出通知。這種情況,一般使用NSNotificationCenter的類方法defaultCenter就獲得默認的通知對象,這樣你就可以給該程序的默認通知中心發(fā)送通知了敌厘。注意:每一個程序都有一個自己的通知中心,即NSNotificationCenter對象朽合。該對象采用單例設(shè)計模式俱两,采用defaultCenter方法就可以獲得唯一的NSNotificationCenter對象饱狂。
注意:NSNotification對象是不可變的,因為一旦創(chuàng)建锋华,對象是不能更改的嗡官。

2.注冊通知:addObserver:selector:name:object:
可以看到除了添加觀察者之外,還有其接收到通知之后的執(zhí)行方法入口毯焕,即selector的實參衍腥。因此為了進行防御式編程,最好先檢查觀察者是否定義了該方法纳猫。例如:添加觀察者代碼有
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(aWindowBecameMain:) name:NSWindowDidBecomeMainNotification object:nil];
這里保證了self定義了aWindowBecameMain:方法婆咸。而對于一個任意的觀察者observer,不能保證其對應(yīng)的selector有aWindowBecameMain:芜辕,可采用[observer respondsToSelector:@selector(aWindowBecameMain:)]] 進行檢查尚骄。所以完整的添加觀察者過程為:
if([observer respondsToSelector:@selector(aWindowBecameMain:)]) { [[NSNotificationCenter defaultCenter] addObserver:observer selector:@selector(aWindowBecameMain:) name:NSWindowDidBecomeMainNotification object:nil]; }
注意到addObserver:selector:name:object:不僅指定一個觀察者,指定通知中心發(fā)送給觀察者的消息侵续,還有接收通知的名字倔丈,以及指定的對象。一般來說不需要指定name和object状蜗,但如果僅僅指定了一個object需五,觀察者將收到該對象的所有通知。例如將上面的代碼中name改為nil,那么觀察者將接收到object對象的所有消息轧坎,但是確定不了接收這些消息的順序宏邮。如果指指定一個通知名稱,觀察者將收到它每次發(fā)出的通知缸血。例如蜜氨,上面的代碼中object為nil,那么客戶對象(self)將收到任何對象發(fā)出NSWindowDidBecomeMainNotification通知捎泻。如果既沒有指定指定object飒炎,也沒有指定name,那么該觀察者將收到所有對象的所有消息笆豁。
3.發(fā)送通知:postNotificationName:object:或者performSelectorOnMainThread:withObject:waitUntilDone:
例如程序可以實現(xiàn)將一個文本可以進行一系列的轉(zhuǎn)換厌丑,例如對于一個實例、RTF格式轉(zhuǎn)換成ASCII格式渔呵。而轉(zhuǎn)換在一個類(如Converter類)的對象中得到處理怒竿,在誠尋執(zhí)行過程中可以加入或者刪除這種轉(zhuǎn)換。而且當(dāng)添加或者刪除Converter操作時扩氢,你的程序可能需要通知其他的對象耕驰,但是這些Converter對象并不需要知道被通知對象是什么,能干什么录豺。你只需要聲明兩個通知朦肘,"ConverterAdded" 和 "ConverterRemoved"饭弓,并且在某一事件發(fā)生時就發(fā)出這兩個通知。
當(dāng)一個用戶安裝或者刪除一個Converter媒抠,它將發(fā)送下面的消息給通知中心:
[[NSNotificationCenter defaultCenter] postNotificationName:@"ConverterAdded" object:self];
或者是
[[NSNotificationCenter defaultCenter] postNotificationName:@"ConverterRemoved" object:self];
通知中心將會區(qū)分它們對象對這些通知感興趣并且通知他們弟断。如果除了關(guān)心觀察者的通知名稱和觀察的對象,還關(guān)心其他之外的對象趴生,那么就把之外的對象放在通知的可選字典中阀趴,或者用方法postNotificationName:object:userInfo:。
而采用performSelectorOnMainThread:withObject:waitUntilDone:則是直接調(diào)用NSNotification的方法postNotification苍匆,而postNotificationName和object參數(shù)可以放到withObject的實參中刘急。例如:

[[NSNotificationCenter defaultCenter] performSelectorOnMainThread:@selector(postNotification:) withObject:notification waitUntilDone:YES];//注意這里的notification
為自定義的一個通知對象,可定義為NSNotification* notification = [NSNotification notificationWithName:@"ConverterAdded"object:self];//那么它的作用與上面的一致

4.移除通知:removeObserver:和removeObserver:name:object:
其中浸踩,removeObserver:是刪除通知中心保存的調(diào)度表一個觀察者的所有入口叔汁,而removeObserver:name:object:是刪除匹配了通知中心保存的調(diào)度表中觀察者的一個入口。
這個比較簡單检碗,直接調(diào)用該方法就行据块。例如:
[[NSNotificationCenter defaultCenter] removeObserver:observer name:nil object:self];
注意參數(shù)notificationObserver為要刪除的觀察者,一定不能置為nil折剃。
PS:這里簡單說一下通知中心保存的調(diào)度表另假。通知中心的調(diào)度表是給一些觀察者指定的一些通知集。一個通知集是通知中心發(fā)出的通知的子集微驶。每個表的入口包含:
通知觀察者(必須要的)浪谴、通知名稱开睡、通知的發(fā)送者因苹。
下圖表示通知集中指定的通知的調(diào)用表入口的四種類型:

1.png

下圖表示四種觀察者的調(diào)度表

2.png

最后,提醒一下觀察者收到通知的順序是沒有定義的篇恒。同時通知發(fā)出和觀察的對象有可能是一樣的扶檐。通知中心同步轉(zhuǎn)發(fā)通知給觀察者,就是說 postNotification: 方法直到接收并處理完通知才返回值胁艰。要想異步的發(fā)送通知款筑,可以使用NSNotificationQueue。在多線程編程中腾么,通知一般是在一個發(fā)出通知的那個線程中轉(zhuǎn)發(fā)奈梳,但也可能是不在同一個線程中轉(zhuǎn)發(fā)通知。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末解虱,一起剝皮案震驚了整個濱河市攘须,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌殴泰,老刑警劉巖于宙,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浮驳,死亡現(xiàn)場離奇詭異,居然都是意外死亡捞魁,警方通過查閱死者的電腦和手機至会,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谱俭,“玉大人奉件,你說我怎么就攤上這事⊥希” “怎么了瓶蚂?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長宣吱。 經(jīng)常有香客問我窃这,道長,這世上最難降的妖魔是什么征候? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任杭攻,我火速辦了婚禮,結(jié)果婚禮上疤坝,老公的妹妹穿的比我還像新娘兆解。我一直安慰自己,他們只是感情好跑揉,可當(dāng)我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布锅睛。 她就那樣靜靜地躺著,像睡著了一般历谍。 火紅的嫁衣襯著肌膚如雪现拒。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天望侈,我揣著相機與錄音印蔬,去河邊找鬼。 笑死脱衙,一個胖子當(dāng)著我的面吹牛侥猬,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播捐韩,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼退唠,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了荤胁?” 一聲冷哼從身側(cè)響起瞧预,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后松蒜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體扔茅,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年秸苗,在試婚紗的時候發(fā)現(xiàn)自己被綠了召娜。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡惊楼,死狀恐怖玖瘸,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情檀咙,我是刑警寧澤雅倒,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站弧可,受9級特大地震影響蔑匣,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜棕诵,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一裁良、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧校套,春花似錦价脾、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至妹孙,卻和暖如春秋柄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背涕蜂。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工华匾, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留映琳,地道東北人机隙。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像萨西,于是被迫代替她去往敵國和親有鹿。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,802評論 2 345

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

  • iOS 提供了一種 “同步的” 消息通知機制NSNotificationCenter谎脯,觀察者只要向消息中心注冊葱跋, ...
    MasterChen閱讀 2,193評論 4 16
  • 前序 通知在我看來娱俺,有好處也有壞處稍味。用好了那就是翻云復(fù)海,上天入地荠卷,無所不能模庐。什么傳值、傳遞動作就是一句話:天氣飄...
    沉默學(xué)飛翔閱讀 10,454評論 30 38
  • 概述 在多數(shù)移動應(yīng)用中任何時候都只能有一個應(yīng)用程序處于活躍狀態(tài)油宜,如果其他應(yīng)用此刻發(fā)生了一些用戶感興趣的那么通過通知...
    莫離_焱閱讀 6,492評論 1 8
  • 轉(zhuǎn)載自南峰子的技術(shù)博客 一個NSNotificationCenter對象(通知中心)提供了在程序中廣播消息的機制掂碱,...
    我消失1314閱讀 876評論 0 2
  • NSNotificationCenter對象(通知中心)提供了在程序中廣播消息的機制,它實質(zhì)上就是一個通知分發(fā)表慎冤。...
    9de75b652cd9閱讀 750評論 0 1