欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

NSRunLoop概述和原理[轉]

系統 2359 0
1.什么是NSRunLoop?
我們會經常看到這樣的代碼:

    - (IBAction)start:(id)sender
{
pageStillLoading = YES;
[NSThread detachNewThreadSelector:@selector(loadPageInBackground:)toTarget:self withObject:nil];
[progress setHidden:NO];
while (pageStillLoading) {
[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];
}
[progress setHidden:YES];
} 

  


這段代碼很神奇的,因為他會“暫停”代碼運行,而且程序運行不會因為這里有一個while循環而受到影響。在[progress setHidden:NO]執行之后,整個函數想暫停了一樣停在循環里面,等loadPageInBackground里面的操作都完成了以后才讓[progress setHidden:YES]運行。這樣做就顯得簡介,而且邏輯很清晰。如果你不這樣做,你就需要在loadPageInBackground里面表示load完成的地方調用[progress setHidden:YES],顯得代碼不緊湊而且容易出錯。
那么具體什么是NSRunLoop呢?其實NSRunLoop的本質是一個消息機制的處理模式。如果你對vc++編程有一定了解,在windows中,有一系列很重要的函數SendMessage,PostMessage,GetMessage,這些都是有關消息傳遞處理的API。但是在你進入到Cocoa的編程世界里面,我不知道你是不是走的太快太匆忙而忽視了這個很重要的問題,Cocoa里面就沒有提及到任何關于消息處理的API,開發者從來也沒有自己去關心過消息的傳遞過程,好像一切都是那么自然,像大自然一樣自然?在Cocoa里面你再也不用去自己定義WM_COMMAD_XXX這樣的宏來標識某個消息,也不用在switch-case里面去對特定的消息做特別的處理。難道是Cocoa里面就沒有了消息機制?答案是否定的,只是Apple在設計消息處理的時候采用了一個更加高明的模式,那就是RunLoop。

2. NSRunLoop工作原理
接下來看一下NSRunLoop具體的工作原理,首先是官方文檔提供的說法,看圖:

NSRunLoop概述和原理[轉]

通過所有的“消息”都被添加到了NSRunLoop中去,而在這里這些消息并分為“input source”和“Timer source” 并在循環中檢查是不是有事件需要發生,如果需要那么就調用相應的函數處理。為了更清晰的解釋,我們來對比VC++和iOS消息處理過程。

VC++中在一切初始化都完成之后程序就開始這樣一個循環了(代碼是從戶sir mfc程序設計課程的slides中截取):

    

 int APIENTRY WinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,LPSTR  lpCmdLine,int nCmdShow){
...
while (GetMessage(&msg, NULL, 0, 0)){
if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg)){
TranslateMessage(&msg);
DispatchMessage(&msg);
}
}
} 

  


可以看到在GetMessage之后就去分發處理消息了,而iOS中main函數中只是調用了UIApplicationMain,那么我們可以介意猜出UIApplicationMain在初始化完成之后就會進入這樣一個情形:

    int UIApplicationMain(...){
...
while(running){
[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:[NSDate distantFuture]];
}
...
} 

  


所以在UIApplicationMain中也是同樣在不斷處理runloop才是的程序沒有退出。剛才的我說了NSRunLoop是一種更加高明的消息處理模式,他就高明在對消息處理過程進行了更好的抽象和封裝,這樣才能是的你不用處理一些很瑣碎很低層次的具體消息的處理,在NSRunLoop中每一個消息就被打包在input source或者是timer source中了,當需要處理的時候就直接調用其中包含的相應對象的處理函數了。所以對外部的開發人員來講,你感受到的就是,把source/timer加入到runloop中,然后在適當的時候類似于[receiver action]這樣的事情發生了。甚至很多時候,你都沒有感受到整個過程前半部分,你只是感覺到了你的某個對象的某個函數調用了。比如在UIView被觸摸時會用touchesBegan/touchesMoved等等函數被調用,也許你會想,“該死的,我都不知道在那里被告知有觸摸消息,這些處理函數就被調用了!?”所以,消息是有的,只是runloop已經幫你做了!為了證明我的觀點,我截取了一張debug touchesBegan的call stack,有圖有真相:


NSRunLoop概述和原理[轉]

NSRunLoop概述和原理[轉]


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 99欧美精品 | 国产成人一区二区三区 | 波多野结衣亚洲一区 | 一级片a| 国产馆精品推荐在线观看 | 久久精品视频16 | 91精品视频在线播放 | 爱操影视 | 日韩欧美中文字幕视频 | 欧美色视频网 | 日韩一区二区三区视频 | a级毛片高清免费视频 | 久久se精品一区精品二区 | 99精品大香线蕉线伊人久久久 | 日日拍夜夜嗷嗷叫视频 | 亚洲欧美日韩中文不卡 | 亚洲一区二区三区中文字幕 | 免费毛片在线视频 | 午夜精品久久久久久久90蜜桃 | 蜜桃五月天 | 亚洲一区二区三区精品视频 | 亚洲综合久久久久久中文字幕 | 欧美激情精品久久久久久黑人 | 欧美v在线 | 网红和老师啪啪对白清晰 | 精品一卡2卡三卡4卡乱码免费 | 日本九九精品一区二区 | cao视频| 草久视频| 久久九九国产精品怡红院 | 免费黄色欧美视频 | 午夜影网 | 国产欧美一区二区三区在线看 | 日本黄视频在线观看 | 婷婷精品国产亚洲AV在线观看 | 婷婷久久综合 | 亚洲v日本v欧美v综合v | 国产精品1区2区3区 国产成人aaa在线视频免费观看 | 亚洲欧美中文字幕 | 精品欧美一区二区三区在线 | 中文字幕精品视频 |