iOS中定位(location manager )出现log日志的解决办法
2017-10-30 12:00
736 查看
最近发现一个问题,自iOS 10.0以后,项目中老是出现有关定位管理者的日志信息,说定位管理者最好放在主线程;在实际开发中,当在子线程中创建定位管理者,有可能收不到回调信息
提示信息如下:
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.
中文翻译为:一个定位管理者创建在子线程,而不是主线程.在开发中,要确保一个定位管理者所在的线程要在运行循环(Run loop)中.在实际开发中,当在子线程中创建定位管理者,有可能收不到回调信息.
解决过程
我找了好久,尝试了好多方法,都无果: 这是在stackoverflow中搜到的解决方法
作者的问题:
比较好的回答:
但我尝试了,也无果.
没办法,有时间了就去尝试.
解决方法:
最终解决方法是在App Delegate 内关于地图或者导航注册信息那一块.
这是我导航注册代码:
//开启导航服务 [BNCoreServices_Instance initServices:@"xxxxxxxxxxxx"]; [BNCoreServices_Instance startServicesAsyn:^{ NSLog(@"导航开启成功"); } fail:^{ NSLog(@"导航开启失败"); }];
我在开启导航服务的时候,使用了异步开启,然后主线程回调开启的结果.
进入百度导航API发现:
/** * 启动服务,同步方法,会导致阻塞 * @param SoundDelete [in]传入遵守BNSoundManagerProtocol的实例 * @return 启动结果 */ - (BOOL)startServices; /** * 启动服务,异步方法 * * @param success 启动成功后回调 success block * @param fail 启动失败后回调 fail block */ -(void)startServicesAsyn:(void (^)(void))success fail:(void (^)(void))fail;
有两个方法开启导航服务:
- 一个是在主线程同步开启,说会导致阻塞;
- 另外一个是异步开启,将结果回调到主线程.
之所以会打印上述日志,是因为我使用了异步开启导航服务.
如果我使用同步开启
[BNCoreServices_Instance startServices];
就不会打印出有关定位的日志信息.
抱歉,我有强迫症,不喜欢日志框有打印,所以我选择了同步开启.
如果你觉得异步加载好,不会阻塞线程,可以无视打印日志的影响,你可以使用异步开启.
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- iOS-定位(location manager )出现log日志解决方法
- iOS崩溃日志中[__NSSetM addObject:]和[__NSArrayM insertObject:atIndex:]的解决办法
- 绿毒越狱IOS4.2.1后未出现cydia或Loader图标的解决办法
- IOS中运行出现如下错误的解决办法
- elipse启动出现问题:an error has occurred.see the log file……解决办法
- iOS运行虚拟器时出现The file "XXX" couldn't be opened because you don't have permission to view it的解决办法
- 关于描述ios证书出现 “此证书的签发者无效的” 解决办法
- iOS之旅--UILabel后边出现一条线的解决办法
- WM6--- 内存卡出现EncFiltLog.menc的解决办法
- iOS中json解析出现的null,nil,NSNumber的解决办法
- outlook出现"定位链接浏览器"错误的解决办法
- DB或DG出现的ORA-16038解决-日志无法归档(startup时log不能archive)
- Create My Site失败,Log中出现空引用的解决办法
- 【转】总结:升级到xcode4.2 iOS sdk 5.0旧版工程编译后出现的警告解决办法
- xcode ios项目出现编译问题的解决办法
- initerrlog: 无法打开错误日志文件 'D:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER\MSSQL\Log 解决办法
- VS 2008 下调试PCL程序出现计算机丢失PCl_common_debug.dll,调试程序出现无法定位到MSVCP90D.dll解决办法
- ESXi主机出现“主机上的系统日志存储在非持久存储器中”解决办法
- Xcode9出现错误safe area layout guide before ios 9 真正解决办法
- iOS开发笔记:编译时出现的错误和解决办法