iOS中定位(location manager )出現(xiàn)log日志的解決辦法
前言
最近發(fā)現(xiàn)一個(gè)問(wèn)題,自iOS 10.0以后,項(xiàng)目中老是出現(xiàn)有關(guān)定位管理者的日志信息,說(shuō)定位管理者最好放在主線程;在實(shí)際開(kāi)發(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)建在子線程,而不是主線程.在開(kāi)發(fā)中,要確保一個(gè)定位管理者所在的線程要在運(yùn)行循環(huán)(Run loop)中.在實(shí)際開(kāi)發(fā)中,當(dāng)在子線程中創(chuàng)建定位管理者,有可能收不到回調(diào)信息.
解決過(guò)程
我找了好久,嘗試了好多方法,都無(wú)果: 這是在stackoverflow中搜到的解決方法
作者的問(wèn)題:
比較好的回答:
但我嘗試了,也無(wú)果.
沒(méi)辦法,有時(shí)間了就去嘗試.
解決方法:
最終解決方法是在App Delegate 內(nèi)關(guān)于地圖或者導(dǎo)航注冊(cè)信息那一塊.
這是我導(dǎo)航注冊(cè)代碼:
//開(kāi)啟導(dǎo)航服務(wù) [BNCoreServices_Instance initServices:@"xxxxxxxxxxxx"]; [BNCoreServices_Instance startServicesAsyn:^{ NSLog(@"導(dǎo)航開(kāi)啟成功"); } fail:^{ NSLog(@"導(dǎo)航開(kāi)啟失敗"); }];
我在開(kāi)啟導(dǎo)航服務(wù)的時(shí)候,使用了異步開(kāi)啟,然后主線程回調(diào)開(kāi)啟的結(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è)方法開(kāi)啟導(dǎo)航服務(wù):
- 一個(gè)是在主線程同步開(kāi)啟,說(shuō)會(huì)導(dǎo)致阻塞;
- 另外一個(gè)是異步開(kāi)啟,將結(jié)果回調(diào)到主線程.
之所以會(huì)打印上述日志,是因?yàn)槲沂褂昧水惒介_(kāi)啟導(dǎo)航服務(wù).
如果我使用同步開(kāi)啟
[BNCoreServices_Instance startServices];
就不會(huì)打印出有關(guān)定位的日志信息.
抱歉,我有強(qiáng)迫癥,不喜歡日志框有打印,所以我選擇了同步開(kāi)啟.
如果你覺(jué)得異步加載好,不會(huì)阻塞線程,可以無(wú)視打印日志的影響,你可以使用異步開(kāi)啟.
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
iOS 自定義返回按鈕保留系統(tǒng)滑動(dòng)返回功能
這篇文章主要介紹了iOS 自定義返回按鈕,保留系統(tǒng)滑動(dòng)返回功能,實(shí)現(xiàn)方法非常簡(jiǎn)單,具有參考借鑒價(jià)值,需要的朋友參考下吧2017-01-01iOS App引導(dǎo)頁(yè)開(kāi)發(fā)教程
這篇文章主要為大家詳細(xì)介紹了iOS App引導(dǎo)頁(yè)開(kāi)發(fā)教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09iOS實(shí)現(xiàn)手指點(diǎn)擊出現(xiàn)波紋的效果
最近在閑暇的時(shí)間做了一個(gè)反饋手指點(diǎn)擊屏幕的效果,用到了CAShapeLayer和基本的動(dòng)畫(huà)知識(shí),實(shí)現(xiàn)的效果很贊,這種效果使用在某些頁(yè)面上肯定會(huì)給用戶更有趣的體驗(yàn),特別是面向兒童的app中。文中給出了詳細(xì)的示例代碼,感興趣的朋友們下面來(lái)一起看看吧。2016-12-12iOS使用xib手動(dòng)實(shí)現(xiàn)動(dòng)畫(huà)效果的方法
下面小編就為大家分享一篇iOS使用xib手動(dòng)實(shí)現(xiàn)動(dòng)畫(huà)效果的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01ios常見(jiàn)加密解密方法(RSA、DES 、AES、MD5)
本篇文章主要介紹了ios常見(jiàn)加密解密方法(RSA、DES 、AES、MD5),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02IOS登錄頁(yè)面動(dòng)畫(huà)、轉(zhuǎn)場(chǎng)動(dòng)畫(huà)開(kāi)發(fā)詳解
本篇文章通過(guò)詳細(xì)的步驟給大家詳細(xì)講述了IOS登錄頁(yè)面動(dòng)畫(huà)、轉(zhuǎn)場(chǎng)動(dòng)畫(huà)開(kāi)發(fā)的詳細(xì)教程,有興趣的朋友參考學(xué)習(xí)下。2018-01-01深入講解iOS開(kāi)發(fā)中應(yīng)用數(shù)據(jù)的存儲(chǔ)方式
這篇文章主要介紹了iOS開(kāi)發(fā)中應(yīng)用數(shù)據(jù)的存儲(chǔ)方式,包括plistXML屬性列表和NSKeydeArchiver歸檔兩個(gè)部分,需要的朋友可以參考下2015-12-12