前言
最近發(fā)現(xiàn)一個(gè)問題,自iOS 10.0以后,項(xiàng)目中老是出現(xiàn)有關(guān)定位管理者的日志信息,說定位管理者最好放在主線程;在實(shí)際開發(fā)中,當(dāng)在子線程中創(chuàng)建定位管理者,有可能收不到回調(diào)信息
提示信息如下:
A location manager (0x7fbafac12560) was created on a dispatch queue executing on a thread other than the main thread. It is the developer's responsibility to ensure that there is a run loop running on the thread on which the location manager object is allocated. In particular, creating location managers in arbitrary dispatch queues (not attached to the main queue) is not supported and will result in callbacks not being received.
中文翻譯為:一個(gè)定位管理者創(chuàng)建在子線程,而不是主線程.在開發(fā)中,要確保一個(gè)定位管理者所在的線程要在運(yùn)行循環(huán)(Run loop)中.在實(shí)際開發(fā)中,當(dāng)在子線程中創(chuàng)建定位管理者,有可能收不到回調(diào)信息.
解決過程
我找了好久,嘗試了好多方法,都無果: 這是在stackoverflow中搜到的解決方法
作者的問題:
比較好的回答:
但我嘗試了,也無果.
沒辦法,有時(shí)間了就去嘗試.
解決方法:
最終解決方法是在App Delegate 內(nèi)關(guān)于地圖或者導(dǎo)航注冊(cè)信息那一塊.
這是我導(dǎo)航注冊(cè)代碼:
//開啟導(dǎo)航服務(wù) [BNCoreServices_Instance initServices:@"xxxxxxxxxxxx"]; [BNCoreServices_Instance startServicesAsyn:^{ NSLog(@"導(dǎo)航開啟成功"); } fail:^{ NSLog(@"導(dǎo)航開啟失敗"); }];
我在開啟導(dǎo)航服務(wù)的時(shí)候,使用了異步開啟,然后主線程回調(diào)開啟的結(jié)果.
進(jìn)入百度導(dǎo)航API發(fā)現(xiàn):
/** * 啟動(dòng)服務(wù),同步方法,會(huì)導(dǎo)致阻塞 * @param SoundDelete [in]傳入遵守BNSoundManagerProtocol的實(shí)例 * @return 啟動(dòng)結(jié)果 */- (BOOL)startServices;/** * 啟動(dòng)服務(wù),異步方法 * * @param success 啟動(dòng)成功后回調(diào) success block * @param fail 啟動(dòng)失敗后回調(diào) fail block */-(void)startServicesAsyn:(void (^)(void))success fail:(void (^)(void))fail;
有兩個(gè)方法開啟導(dǎo)航服務(wù):
- 一個(gè)是在主線程同步開啟,說會(huì)導(dǎo)致阻塞;
- 另外一個(gè)是異步開啟,將結(jié)果回調(diào)到主線程.
之所以會(huì)打印上述日志,是因?yàn)槲沂褂昧水惒介_啟導(dǎo)航服務(wù).
如果我使用同步開啟
[BNCoreServices_Instance startServices];
就不會(huì)打印出有關(guān)定位的日志信息.
抱歉,我有強(qiáng)迫癥,不喜歡日志框有打印,所以我選擇了同步開啟.
如果你覺得異步加載好,不會(huì)阻塞線程,可以無視打印日志的影響,你可以使用異步開啟.
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)VEVB武林網(wǎng)的支持。
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注