iOS中如何正確釋放GCD定時(shí)器(dispatch_source_t)

iOS中如何正確釋放GCD定時(shí)器(dispatch_source_t)

一.現(xiàn)象

通過(guò)云跡的崩潰,查詢到崩潰在福袋的釋放緩存的方法(clearLuckyBagInfo)中,然后就查看這個(gè)釋放緩存的方法,發(fā)現(xiàn)這個(gè)方法中都是簡(jiǎn)單的釋放,也有保護(hù)操作,就很納悶兒為什么崩潰在了這里.

- (void)clearLuckyBagInfo{
    self.LuckyBagDetailModel = nil;
    self.contentView = nil;
    self.residueTime = 0;
    if (self.countDownTimer) {
        dispatch_cancel(self.countDownTimer);
        self.countDownTimer = nil;
    }
    self.isSuspendTimer = NO;
    self.liveDto = nil;
    [self.winPriceArray removeAllObjects];
    self.winPriceArray = nil;
    if (self.tenSecondTimer) {
        dispatch_cancel(self.tenSecondTimer);
        self.tenSecondTimer = nil;
    }
    self.IsReciveLotteryMessage = NO;
    self.timeGone = 0;
}

二.查詢和驗(yàn)證

查看了上面的釋放方法中,通過(guò)分析只有可能是定時(shí)器釋放時(shí)引起的crash,然后就去查詢dispatch_source_t的crash問(wèn)題,結(jié)果發(fā)現(xiàn)了在dispatch_suspend 狀態(tài)下,不能去釋放定時(shí)器,如果此時(shí)釋放定時(shí)器,就會(huì)crash.

20210901143117503.png

然后查看代碼中為了定時(shí)器的時(shí)間退到后臺(tái)再回來(lái)時(shí)的準(zhǔn)確性,就在退到后臺(tái)中將定時(shí)器掛起(dispatch_suspend ),回到前臺(tái)是發(fā)現(xiàn)福袋未結(jié)束時(shí)就重新開(kāi)啟定時(shí)器(dispatch_resume),如果用戶從后臺(tái)回到前臺(tái)時(shí)福袋已經(jīng)結(jié)束了,這時(shí)就沒(méi)調(diào)用dispatch_resume開(kāi)啟定時(shí)器,這時(shí)候釋放定時(shí)器就會(huì)引起crash.然后就和測(cè)試驗(yàn)證了這個(gè)場(chǎng)景,確實(shí)會(huì)引起crash.

// 程序進(jìn)入后臺(tái)
- (void)resignActive:(NSNotification *)notification {
    if ([self.LuckyBagDetailModel.drawStatus isEqualToString:@"0"] && self.countDownTimer) {
        [self pauseCountDownTimer];//掛起定時(shí)器
        NSDate* currentdate = [NSDate dateWithTimeIntervalSinceNow:0];
        NSTimeInterval a=[currentdate timeIntervalSince1970];
        [[NSUserDefaults standardUserDefaults] setObject:@(a) forKey:snliveLuckyBagResignActiveDate];
    }
}
// 程序進(jìn)入前臺(tái)
- (void)becomeActive:(NSNotification *)notification {
    if ([self.LuckyBagDetailModel.drawStatus isEqualToString:@"0"] && self.countDownTimer) {
        [self resumeCountDownTimer];//重啟定時(shí)器
        NSDate* currentdate = [NSDate dateWithTimeIntervalSinceNow:0];
        NSTimeInterval a=[currentdate timeIntervalSince1970];
        NSTimeInterval resignDate = [[NSUserDefaults standardUserDefaults] doubleForKey:snliveLuckyBagResignActiveDate];
        self.timeGone = a - resignDate;
    }else{
        self.timeGone = 0;
    }
    
}

三.解決辦法

1.設(shè)置屬性 isSuspendTimer 記錄定時(shí)器timer是否 處于dispatch_suspend的狀態(tài)具温。在定時(shí)器掛起時(shí)設(shè)置為YES,重新啟動(dòng)時(shí)設(shè)置為NO. 只要在 調(diào)用dealloc 時(shí)判斷下浊伙,已經(jīng)調(diào)用過(guò) dispatch_suspend 則再調(diào)用下 dispatch_resume后再cancel途样,然后再釋放timer蒿讥。就不會(huì)引起崩潰了.


//計(jì)時(shí)器是否掛起
@property (nonatomic, assign) BOOL isSuspendTimer;

- (void)pauseCountDownTimer{//掛起
    if(self.countDownTimer){
        self.isSuspendTimer = YES;
        dispatch_suspend(_countDownTimer);
    }
}
- (void)resumeCountDownTimer{//恢復(fù)
    if(self.countDownTimer){
        self.isSuspendTimer = NO;
        dispatch_resume(_countDownTimer);
    }
}

- (void)clearLuckyBagInfo{
    self.LuckyBagDetailModel = nil;
    self.contentView = nil;
    self.residueTime = 0;
    //釋放定時(shí)器是先判斷該定時(shí)器是否被掛起
    if (self.countDownTimer) {
        if (self.isSuspendTimer) {
            dispatch_resume(self.countDownTimer);
        }
        dispatch_cancel(self.countDownTimer);
        self.countDownTimer = nil;
    }
    self.isSuspendTimer = NO;
    self.liveDto = nil;
    [self.winPriceArray removeAllObjects];
    self.winPriceArray = nil;
    if (self.tenSecondTimer) {
        dispatch_cancel(self.tenSecondTimer);
        self.tenSecondTimer = nil;
    }
    self.IsReciveLotteryMessage = NO;
    self.timeGone = 0;
}

四.總結(jié)(dispatch_source_t)

dispatch_suspend 狀態(tài)下直接釋放當(dāng)前控制器或者釋放定時(shí)器璧尸,會(huì)導(dǎo)致定時(shí)器崩潰膝宁。并且初始狀態(tài)(未調(diào)用dispatch_resume)厉斟、掛起狀態(tài)珍语,都不能直接調(diào)用dispatch_source_cancel(timer),調(diào)用就會(huì)導(dǎo)致app閃退集漾。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末切黔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子具篇,更是在濱河造成了極大的恐慌纬霞,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,589評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驱显,死亡現(xiàn)場(chǎng)離奇詭異诗芜,居然都是意外死亡瞳抓,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門伏恐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)孩哑,“玉大人,你說(shuō)我怎么就攤上這事翠桦『嵫眩” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 165,933評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵销凑,是天一觀的道長(zhǎng)丛晌。 經(jīng)常有香客問(wèn)我,道長(zhǎng)闻鉴,這世上最難降的妖魔是什么茵乱? 我笑而不...
    開(kāi)封第一講書人閱讀 58,976評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮孟岛,結(jié)果婚禮上瓶竭,老公的妹妹穿的比我還像新娘。我一直安慰自己渠羞,他們只是感情好斤贰,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,999評(píng)論 6 393
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著次询,像睡著了一般荧恍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上屯吊,一...
    開(kāi)封第一講書人閱讀 51,775評(píng)論 1 307
  • 那天送巡,我揣著相機(jī)與錄音,去河邊找鬼盒卸。 笑死骗爆,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蔽介。 我是一名探鬼主播摘投,決...
    沈念sama閱讀 40,474評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼虹蓄!你這毒婦竟也來(lái)了犀呼?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,359評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤薇组,失蹤者是張志新(化名)和其女友劉穎外臂,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體律胀,經(jīng)...
    沈念sama閱讀 45,854評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡专钉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,007評(píng)論 3 338
  • 正文 我和宋清朗相戀三年挑童,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了累铅。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片跃须。...
    茶點(diǎn)故事閱讀 40,146評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖娃兽,靈堂內(nèi)的尸體忽然破棺而出菇民,到底是詐尸還是另有隱情,我是刑警寧澤投储,帶...
    沈念sama閱讀 35,826評(píng)論 5 346
  • 正文 年R本政府宣布第练,位于F島的核電站,受9級(jí)特大地震影響玛荞,放射性物質(zhì)發(fā)生泄漏娇掏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,484評(píng)論 3 331
  • 文/蒙蒙 一勋眯、第九天 我趴在偏房一處隱蔽的房頂上張望婴梧。 院中可真熱鬧,春花似錦客蹋、人聲如沸塞蹭。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,029評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)番电。三九已至,卻和暖如春辆琅,著一層夾襖步出監(jiān)牢的瞬間漱办,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,153評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工婉烟, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留娩井,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,420評(píng)論 3 373
  • 正文 我出身青樓隅很,卻偏偏與公主長(zhǎng)得像撞牢,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子叔营,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,107評(píng)論 2 356

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