IOS RunLoop檢測(cè)卡頓原理分析(易懂)

今天主要講解一下個(gè)人對(duì)Runloop 應(yīng)用之-- 檢測(cè)卡頓的理解乐埠。廢話(huà)不多說(shuō)直接上圖抗斤,大神輕噴囚企。

眾所周知Runloop是一個(gè)循環(huán),那么每一個(gè)循環(huán)瑞眼。下面是一張Runloop的流程執(zhí)行圖龙宏。展示一個(gè)Runloop這個(gè)循環(huán)在每一個(gè)循環(huán)之中會(huì)做一些什么樣子的事情。那么我們一般的事件是分為兩種一種是Source0 一種是Source1伤疙。這兩個(gè)Source的作用我已經(jīng)粘在下面了:


? Source1 :基于mach_Port的,來(lái)自系統(tǒng)內(nèi)核或者其他進(jìn)程或線(xiàn)程的事件银酗,可以主動(dòng)喚醒休眠中的RunLoop(iOS里進(jìn)程間通信開(kāi)發(fā)過(guò)程中我們一般不主動(dòng)使用)。mach_port大家就理解成進(jìn)程間相互發(fā)送消息的一種機(jī)制就好, 比如屏幕點(diǎn)擊, 網(wǎng)絡(luò)數(shù)據(jù)的傳輸都會(huì)觸發(fā)sourse1徒像。

? Source0 :非基于Port的 處理事件黍特,什么叫非基于Port的呢?就是說(shuō)你這個(gè)消息不是其他進(jìn)程或者內(nèi)核直接發(fā)送給你的锯蛀。一般是APP內(nèi)部的事件, 比如hitTest:withEvent的處理,?performSelectors的事件.

我們觸摸屏幕,先摸到硬件(屏幕)灭衷,屏幕表面的事件會(huì)被IOKit先包裝成Event,通過(guò)mach_Port傳給正在活躍的APP , Event先告訴source1(mach_port),source1喚醒RunLoop, 然后將事件Event分發(fā)給source0,然后由source0來(lái)處理。

摘自https://blog.csdn.net/u014600626/article/details/105146577




我們的卡頓當(dāng)然是針對(duì)主線(xiàn)程來(lái)說(shuō)的旁涤,所以我們這里只討論主線(xiàn)程的Runloop翔曲。檢測(cè)的原理也很簡(jiǎn)單,首先我們要理解卡頓是什么劈愚? 卡頓就是不流暢瞳遍,那為什么不流暢呢? 因?yàn)槟阒骶€(xiàn)程做了其他的事情占用了CPU和GPU的資源 導(dǎo)致了它們給屏幕渲染的資源就變少了菌羽,那么就會(huì)導(dǎo)致每一秒可以處理出來(lái)的畫(huà)面不滿(mǎn)足60幀傅蹂,造成丟幀就會(huì)感覺(jué)卡。 所以說(shuō)白了檢測(cè)卡頓就是檢測(cè)哪一段代碼占用主線(xiàn)程的Runloop資源(source)比較多我們找出來(lái)給他處理掉或者丟到子線(xiàn)程里面就行了算凿。

那下面開(kāi)始介紹一下檢測(cè)卡頓的原理份蝴, 因?yàn)橐粋€(gè)Loop的順序是如上圖所示, 那么在處理完Source1之后會(huì)有一個(gè)wait的狀態(tài)變化氓轰,我們檢測(cè)卡頓的原理就是在子線(xiàn)程 開(kāi)辟一個(gè)死循環(huán)和一個(gè)observer,把這個(gè)observer添加到主線(xiàn)程Runloop下的所有Mode里面 目的就是為了檢測(cè)主線(xiàn)程Runloop的狀態(tài)變化婚夫, 然后通過(guò)這個(gè)死循環(huán)不停的判斷observer的狀態(tài),判斷一次Source1到下一次Source0之間的時(shí)間署鸡, 這個(gè)時(shí)候你要自己定義一個(gè)時(shí)間案糙, 如果發(fā)現(xiàn)兩次Source之間的時(shí)間大于你默認(rèn)的時(shí)間了,那么你就認(rèn)為出現(xiàn)了導(dǎo)致卡頓的操作靴庆,這個(gè)時(shí)候就需要調(diào)用一些底層的函數(shù)來(lái)獲取到當(dāng)前的程序執(zhí)行了哪些函數(shù)时捌,并且這些函數(shù)的堆棧信息都是什么,把他們提取出來(lái)進(jìn)行反編譯等操作就可以大致定位到導(dǎo)致卡頓的函數(shù)了炉抒, 當(dāng)然你定義的這個(gè)時(shí)間越精細(xì)奢讨,定位也越準(zhǔn)確 不過(guò)可能產(chǎn)生的問(wèn)題也越多。

關(guān)于如何獲取堆棧信息看這里https://juejin.cn/post/6910791727670362125講的很清楚焰薄,包括我們的錯(cuò)誤日志收集也會(huì)用到這里的技術(shù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末拿诸,一起剝皮案震驚了整個(gè)濱河市扒袖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌亩码,老刑警劉巖季率,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異描沟,居然都是意外死亡飒泻,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén)吏廉,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)泞遗,“玉大人,你說(shuō)我怎么就攤上這事迟蜜。” “怎么了啡省?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵娜睛,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我卦睹,道長(zhǎng)畦戒,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任结序,我火速辦了婚禮障斋,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘徐鹤。我一直安慰自己垃环,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布返敬。 她就那樣靜靜地躺著遂庄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪劲赠。 梳的紋絲不亂的頭發(fā)上涛目,一...
    開(kāi)封第一講書(shū)人閱讀 49,749評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音凛澎,去河邊找鬼霹肝。 笑死,一個(gè)胖子當(dāng)著我的面吹牛塑煎,可吹牛的內(nèi)容都是我干的沫换。 我是一名探鬼主播,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼最铁,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼苗沧!你這毒婦竟也來(lái)了刊棕?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤待逞,失蹤者是張志新(化名)和其女友劉穎甥角,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體识樱,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡嗤无,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了怜庸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片当犯。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖割疾,靈堂內(nèi)的尸體忽然破棺而出嚎卫,到底是詐尸還是另有隱情,我是刑警寧澤宏榕,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布拓诸,位于F島的核電站,受9級(jí)特大地震影響麻昼,放射性物質(zhì)發(fā)生泄漏奠支。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一抚芦、第九天 我趴在偏房一處隱蔽的房頂上張望倍谜。 院中可真熱鬧,春花似錦叉抡、人聲如沸尔崔。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)您旁。三九已至,卻和暖如春轴捎,著一層夾襖步出監(jiān)牢的瞬間鹤盒,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工侦副, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留侦锯,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓秦驯,卻偏偏與公主長(zhǎng)得像尺碰,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348