欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS中定位(location manager )出現(xiàn)log日志的解決辦法

 更新時(shí)間:2017年10月30日 12:00:33   作者:Mazy_ma  
這篇文章主要給大家介紹了關(guān)于iOS中定位(location manager )出現(xiàn)log日志的解決辦法,文中通過(guò)示例代碼將解決的辦法介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。

前言

最近發(fā)現(xiàn)一個(gè)問(wèn)題,自iOS 10.0以后,項(xiàng)目中老是出現(xiàn)有關(guān)定位管理者的日志信息,說(shuō)定位管理者最好放在主線程;在實(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)信息.

解決過(guò)程

我找了好久,嘗試了好多方法,都無(wú)果: 這是在stackoverflow中搜到的解決方法

作者的問(wèn)題:

比較好的回答:

但我嘗試了,也無(wú)果.

沒(méi)辦法,有時(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è)是在主線程同步開啟,說(shuō)會(huì)導(dǎo)致阻塞;

     - 另外一個(gè)是異步開啟,將結(jié)果回調(diào)到主線程.

之所以會(huì)打印上述日志,是因?yàn)槲沂褂昧水惒介_啟導(dǎo)航服務(wù).

如果我使用同步開啟

[BNCoreServices_Instance startServices];

就不會(huì)打印出有關(guān)定位的日志信息.

抱歉,我有強(qiáng)迫癥,不喜歡日志框有打印,所以我選擇了同步開啟.

如果你覺(jué)得異步加載好,不會(huì)阻塞線程,可以無(wú)視打印日志的影響,你可以使用異步開啟.

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

最新評(píng)論