block 備忘錄

引子

半夜突然想寫點(diǎn)什么笆载,又不想填之前的坑……因為懶锤躁,然后就想到了這個,感覺這應(yīng)該算是block相關(guān)技巧狼讨,就根據(jù)缺總的提示做了一個測試贝淤,順便再挖下一個大坑,以后遇到有block相關(guān)的問題就更新在這里

不知不覺中好像又挖了一個大坑…….png

挖坑這種事嘛政供,填不填不重要…重要的是要經(jīng)常挖…

1. block 異步操作執(zhí)行順序相關(guān)

起因是這個:

66AEA76053CB8DD66B46656F62D1B642.jpg
B0F7BE74AFA0E28362230A39764C1283.jpg

代碼是這樣:

0039E5D0D402D4467FA0468E5F58A546.jpg

簡單的說就是將某個耗時任務(wù)塞進(jìn)隊列播聪,必須等到該耗時任務(wù)完成后判斷某個返回值的狀態(tài),然后在主線程中更改預(yù)設(shè)的BOOL返回值布隔。

但是實(shí)際操作中卻出現(xiàn)了獲取返回值總是先一步于異步線程(block)執(zhí)行完畢离陶,相當(dāng)于做了無用功。

打開xcode 隨便添加了一個按鈕及對應(yīng)的方法衅檀,照著缺總的提示寫了一下

1 . 模擬假想情況

- (void)test1 {
    NSLog(@"開始測試——————Step.1");
    __block BOOL isDone = NO;
    dispatch_queue_t defaultQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    dispatch_async(defaultQueue, ^{
        for (int i = 0; i < 1000000; i++) {
            if (i == 999999) {
                NSLog(@"循環(huán)結(jié)束——————Step.2");
                isDone = YES;
            }
        }
    });
    NSLog(@"執(zhí)行完畢——————Step.3");
}

測試結(jié)果

85988E6F-DB08-4BDD-B11F-B7CA217FE50A.png

預(yù)料中的結(jié)果招刨,耗時操作在 執(zhí)行完畢后才顯示出來

2 . 模擬出現(xiàn)問題的環(huán)境……

- (void)test2 {
    NSLog(@"開始測試——————Step.1");
    __block BOOL isDone = NO;
    dispatch_queue_t defaultQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    dispatch_async(defaultQueue, ^{
        for (int i = 0; i < 1000000; i++) {
            if (i == 999999) {
                 NSLog(@"循環(huán)結(jié)束——————Step.2");
                isDone = YES;
            }
        }
        dispatch_async(dispatch_get_main_queue(), ^{
            if (isDone == YES) {
                NSLog(@"執(zhí)行完畢——————Step.3");
            }
        });
    });
    NSLog(@"不能判斷BOOL值是否已經(jīng)改變----Step.4");
}

執(zhí)行結(jié)果

23469DFB-F725-4523-B18A-7B58C1D70AD5.png

應(yīng)該就是差不多就是這個樣子,盡管在隊列里面添加了get_main_queue事件哀军,step.2 step3 也是按照順序執(zhí)行了计济,但是step.4 仍然先一步于異步任務(wù)之前執(zhí)行了。如果說接下來的需要執(zhí)行的任務(wù)塞在step3那個位置不合適的話排苍,那就有些蛋疼了沦寂。

3 . **正確的 體位 打開方式 **

- (void)test3 {
    NSLog(@"開始測試——————Step.1");
    __block BOOL isDone = NO;
    dispatch_queue_t defaultQueue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
    dispatch_async(defaultQueue, ^{
        for (int i = 0; i < 1000000; i++) {
            if (i == 999999) {
                NSLog(@"循環(huán)結(jié)束——————Step.2");
                
            }
        }
        isDone = YES;
        NSLog(@"執(zhí)行完畢——————Step.3");
    });
    while (!isDone) {
        NSDate *date = [NSDate distantFuture];
        [[NSRunLoop currentRunLoop] runMode:NSDefaultRunLoopMode beforeDate:date];
         NSLog(@"喚醒線程");
    }
    NSLog(@"Next To Do----Step.4");
    NSLog(@"%d",isDone);
}

執(zhí)行結(jié)果

D7646AD9-1ECF-45E8-A009-3A1EE7675AC7.png

算是達(dá)到需要的效果了

核心思想是 通過runLoop 讓封裝的block所在線程休眠,而其結(jié)果的判斷回調(diào)會將其喚醒淘衙,然后才執(zhí)行下一步传藏。

唉.png

話說 NSDate *date = [NSDate distantFuture]; 我楞了好久…看著好眼熟,就是想不起來干嘛用的…


我為什么那么喜歡挖坑呢……


8月

逛博客的時候突然看到runloop的一篇文章

1.只有在為你的程序創(chuàng)建次線程的時候彤守,才需要運(yùn)行run loop毯侦。對于程序的主線程而言,run loop是關(guān)鍵部分具垫。Cocoa提供了運(yùn)行主線程run loop的代碼同時也會自動運(yùn)行run loop侈离。IOS程序UIApplication中的run方法在程序正常啟動的時候就會啟動run loop。如果你使用xcode提供的模板創(chuàng)建的程序筝蚕,那你永遠(yuǎn)不需要自己去啟動run loop

2.在多線程中卦碾,你需要判斷是否需要run loop铺坞。如果需要run loop,那么你要負(fù)責(zé)配置run loop并啟動洲胖。你不需要在任何情況下都去啟動run loop济榨。比如,你使用線程去處理一個預(yù)先定義好的耗時極長的任務(wù)時绿映,你就可以毋需啟動run loop擒滑。Run loop只在你要和線程有交互時才需要

配合上面測試的東西有了一點(diǎn)點(diǎn)頓悟的感覺 ,果然還是要結(jié)合實(shí)際情況叉弦,如果光是單純的這么一段文字我也許看過就忘了丐一。

感覺總結(jié)的很好,正是因為與線程發(fā)生了交互淹冰,才需要對runloop進(jìn)行一定的操作库车。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市榄棵,隨后出現(xiàn)的幾起案子凝颇,更是在濱河造成了極大的恐慌,老刑警劉巖疹鳄,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拧略,死亡現(xiàn)場離奇詭異,居然都是意外死亡瘪弓,警方通過查閱死者的電腦和手機(jī)垫蛆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來腺怯,“玉大人袱饭,你說我怎么就攤上這事∏赫迹” “怎么了虑乖?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長晾虑。 經(jīng)常有香客問我疹味,道長,這世上最難降的妖魔是什么帜篇? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任糙捺,我火速辦了婚禮,結(jié)果婚禮上笙隙,老公的妹妹穿的比我還像新娘洪灯。我一直安慰自己,他們只是感情好竟痰,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布签钩。 她就那樣靜靜地躺著掏呼,像睡著了一般。 火紅的嫁衣襯著肌膚如雪边臼。 梳的紋絲不亂的頭發(fā)上哄尔,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天假消,我揣著相機(jī)與錄音柠并,去河邊找鬼。 笑死富拗,一個胖子當(dāng)著我的面吹牛臼予,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播啃沪,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼粘拾,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了创千?” 一聲冷哼從身側(cè)響起缰雇,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎追驴,沒想到半個月后械哟,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡殿雪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年暇咆,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片丙曙。...
    茶點(diǎn)故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡爸业,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出亏镰,到底是詐尸還是另有隱情扯旷,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布索抓,位于F島的核電站钧忽,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏纸兔。R本人自食惡果不足惜惰瓜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望汉矿。 院中可真熱鬧崎坊,春花似錦、人聲如沸洲拇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至男翰,卻和暖如春另患,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蛾绎。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工昆箕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人租冠。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓鹏倘,卻偏偏與公主長得像,于是被迫代替她去往敵國和親顽爹。 傳聞我的和親對象是個殘疾皇子纤泵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評論 2 353

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