iOS開發(fā)——__ZL17_WebTryThreadLockb

sdk 中涉及到 UI 操作的時候疫赎,一定要注意線程問題目胡!一定要注意線程問題!一定要注意線程問題!

從最初開始學(xué)習(xí) iOS 的時候姻采,我們就被告知 UI 操作一定要放在主線程進(jìn)行盯串,這是因?yàn)?UIKit 的方法不是線程安全的胞枕,保證線程安全需要極大的開銷羹与。

試想一下幾種場景:

  • 兩個線程同時設(shè)置同一個背景圖片,則很有可能因?yàn)楫?dāng)前圖片被釋放了兩次而導(dǎo)致應(yīng)用崩潰爹橱;
  • 兩個線程同時設(shè)置同一個 UIView 的背景色萨螺,則很有可能渲染顯示的是顏色 A,而此時在 UIView 邏輯樹上的背景顏色屬性為 B愧驱;
  • 兩個線程同時操作 View 的樹形結(jié)構(gòu):在線程 A 中 for 循環(huán)遍歷并操作當(dāng)前 View 的所有 subView慰技,而此時線程 B 中將某個 subView 直接刪除,這就導(dǎo)致了錯亂组砚,甚至導(dǎo)致應(yīng)用崩潰吻商。

出了什么問題?

最近 hybrid sdk 收尾惫确,偶然發(fā)現(xiàn)線上有一類 crash 最近兩個版本穩(wěn)步上升手报,而且可以肯定的是我負(fù)責(zé)的 sdk 提供的 web 容器導(dǎo)致的蚯舱,__ZL17_WebTryThreadLockb 是函數(shù)調(diào)用棧最后調(diào)用的 api改化。

crash 線程調(diào)用棧詳細(xì)如下:

Thread 17 Crashed:
0   WebCore                              __ZL17_WebTryThreadLockb
1   WebCore                              _WebThreadLock
2   UIKit                                -[UIWebBrowserView resignFirstResponder]
3   UIKit                                -[UIResponder _resignIfContainsFirstResponder]
4   UIKit                                -[UIView(Hierarchy) _willMoveToWindow:]
5   UIKit                                -[UIView(Internal) _addSubview:positioned:relativeTo:]
6   UIKit                                ___53-[_UINavigationParallaxTransition animateTransition:]_block_invoke_2
7   UIKit                                +[UIView(Animation) performWithoutAnimation:]
8   UIKit                                ___53-[_UINavigationParallaxTransition animateTransition:]_block_invoke
9   UIKit                                +[UIView(Internal) _performBlockDelayingTriggeringResponderEvents:]
10  UIKit                                -[_UINavigationParallaxTransition animateTransition:]
11  UIKit                                -[UINavigationController _startCustomTransition:]
12  UIKit                                -[UINavigationController _startDeferredTransitionIfNeeded:]
13  UIKit                                -[UINavigationController __viewWillLayoutSubviews]
14  UIKit                                -[UILayoutContainerView layoutSubviews]
15  UIKit                                -[UIView(CALayerDelegate) layoutSublayersOfLayer:]
16  QuartzCore                           -[CALayer layoutSublayers]
17  QuartzCore                           __ZN2CA5Layer16layout_if_neededEPNS_11TransactionE
18  QuartzCore                           __ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE
19  QuartzCore                           __ZN2CA7Context18commit_transactionEPNS_11TransactionE
20  QuartzCore                           __ZN2CA11Transaction6commitEv
21  QuartzCore                           __ZN2CA11Transaction14release_threadEPv
22  libsystem_pthread.dylib              __pthread_tsd_cleanup
23  libsystem_pthread.dylib              __pthread_exit
24  libsystem_pthread.dylib              __pthread_wqthread
25  libsystem_pthread.dylib              _start_wqthread

原因是什么?

Stack Overflow 上的問題和解答貼出兩個大家一起參考:

app-crash-no-idea-why
ios-webtrythreadlock-crash

根本原因:Tried to obtain the web lock from a thread other than the main thread or the web thread.

問題定位

ABAuthorizationStatus authStatus = ABAddressBookGetAuthorizationStatus();
    if (authStatus == kABAuthorizationStatusNotDetermined)
    {
        //獲取授權(quán)
        ABAddressBookRef addressBook = ABAddressBookCreate();
        ABAddressBookRequestAccessWithCompletion( addressBook, ^(bool granted, CFErrorRef error) {
            if (granted)
            {
                [self openContact];
            }
            else
            {
                [self showAlertView];
            }
        });
    }

之前草率的確定為上述代碼問題枉昏,上述代碼確實(shí)存在兩個問題

  1. 內(nèi)存泄漏
  2. 非主線程調(diào)用 UI 操作

但重新看 crash 調(diào)用棧陈肛,確定并不會是 AddressBook 導(dǎo)致,而真實(shí)原因已無從考證兄裂。
更新文章句旱,留作后人查閱阳藻。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市谈撒,隨后出現(xiàn)的幾起案子腥泥,更是在濱河造成了極大的恐慌,老刑警劉巖啃匿,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蛔外,死亡現(xiàn)場離奇詭異,居然都是意外死亡溯乒,警方通過查閱死者的電腦和手機(jī)夹厌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來裆悄,“玉大人矛纹,你說我怎么就攤上這事」饧冢” “怎么了或南?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長艾君。 經(jīng)常有香客問我迎献,道長,這世上最難降的妖魔是什么腻贰? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任吁恍,我火速辦了婚禮,結(jié)果婚禮上播演,老公的妹妹穿的比我還像新娘冀瓦。我一直安慰自己,他們只是感情好写烤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布翼闽。 她就那樣靜靜地躺著,像睡著了一般洲炊。 火紅的嫁衣襯著肌膚如雪感局。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天暂衡,我揣著相機(jī)與錄音询微,去河邊找鬼。 笑死狂巢,一個胖子當(dāng)著我的面吹牛撑毛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播唧领,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼藻雌,長吁一口氣:“原來是場噩夢啊……” “哼雌续!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起胯杭,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤驯杜,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后做个,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體艇肴,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年叁温,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片膝但。...
    茶點(diǎn)故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡冲九,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出跟束,到底是詐尸還是另有隱情莺奸,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布冀宴,位于F島的核電站灭贷,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏略贮。R本人自食惡果不足惜甚疟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望逃延。 院中可真熱鬧览妖,春花似錦、人聲如沸揽祥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽拄丰。三九已至府树,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間料按,已是汗流浹背奄侠。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留站绪,地道東北人遭铺。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像恢准,于是被迫代替她去往敵國和親魂挂。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評論 2 354

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