服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - IOS - iOS中定位(location manager )出现log日志的解决办法

iOS中定位(location manager )出现log日志的解决办法

2021-04-04 17:08Mazy_ma IOS

这篇文章主要给大家介绍了关于iOS中定位(location manager )出现log日志的解决办法,文中通过示例代码将解决的办法介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。

前言

最近发现一个问题,自ios 10.0以后,项目中老是出现有关定位管理者的日志信息,说定位管理者最好放在主线程;在实际开发中,当在子线程中创建定位管理者,有可能收不到回调信息

提示信息如下:

iOS中定位(location manager )出现log日志的解决办法

?
1
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中搜到的解决方法

作者的问题:

iOS中定位(location manager )出现log日志的解决办法

比较好的回答:

iOS中定位(location manager )出现log日志的解决办法

iOS中定位(location manager )出现log日志的解决办法

但我尝试了,也无果.

没办法,有时间了就去尝试.

解决方法:

最终解决方法是在app delegate 内关于地图或者导航注册信息那一块.

这是我导航注册代码:

?
1
2
3
4
5
6
7
//开启导航服务
[bncoreservices_instance initservices:@"xxxxxxxxxxxx"];
[bncoreservices_instance startservicesasyn:^{
 nslog(@"导航开启成功");
} fail:^{
 nslog(@"导航开启失败");
}];

我在开启导航服务的时候,使用了异步开启,然后主线程回调开启的结果.
进入百度导航api发现:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
/**
 * 启动服务,同步方法,会导致阻塞
 * @param sounddelete [in]传入遵守bnsoundmanagerprotocol的实例
 * @return 启动结果
 */
- (bool)startservices;
 
/**
 * 启动服务,异步方法
 *
 * @param success  启动成功后回调 success block
 * @param fail   启动失败后回调 fail block
 */
-(void)startservicesasyn:(void (^)(void))success fail:(void (^)(void))fail;

有两个方法开启导航服务:

     - 一个是在主线程同步开启,说会导致阻塞;

     - 另外一个是异步开启,将结果回调到主线程.

之所以会打印上述日志,是因为我使用了异步开启导航服务.

如果我使用同步开启

?
1
[bncoreservices_instance startservices];

就不会打印出有关定位的日志信息.

抱歉,我有强迫症,不喜欢日志框有打印,所以我选择了同步开启.

如果你觉得异步加载好,不会阻塞线程,可以无视打印日志的影响,你可以使用异步开启.

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。

原文链接:http://blog.csdn.net/mazy_ma/article/details/53080656

延伸 · 阅读

精彩推荐
  • IOS解析iOS开发中的FirstResponder第一响应对象

    解析iOS开发中的FirstResponder第一响应对象

    这篇文章主要介绍了解析iOS开发中的FirstResponder第一响应对象,包括View的FirstResponder的释放问题,需要的朋友可以参考下...

    一片枫叶4662020-12-25
  • IOSIOS 屏幕适配方案实现缩放window的示例代码

    IOS 屏幕适配方案实现缩放window的示例代码

    这篇文章主要介绍了IOS 屏幕适配方案实现缩放window的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    xiari5772021-06-01
  • IOS关于iOS自适应cell行高的那些事儿

    关于iOS自适应cell行高的那些事儿

    这篇文章主要给大家介绍了关于iOS自适应cell行高的那些事儿,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的...

    daisy6092021-05-17
  • IOSIOS开发之字典转字符串的实例详解

    IOS开发之字典转字符串的实例详解

    这篇文章主要介绍了IOS开发之字典转字符串的实例详解的相关资料,希望通过本文能帮助到大家,让大家掌握这样的方法,需要的朋友可以参考下...

    苦练内功5832021-04-01
  • IOSiOS中tableview 两级cell的展开与收回的示例代码

    iOS中tableview 两级cell的展开与收回的示例代码

    本篇文章主要介绍了iOS中tableview 两级cell的展开与收回的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    J_Kang3862021-04-22
  • IOSiOS布局渲染之UIView方法的调用时机详解

    iOS布局渲染之UIView方法的调用时机详解

    在你刚开始开发 iOS 应用时,最难避免或者是调试的就是和布局相关的问题,下面这篇文章主要给大家介绍了关于iOS布局渲染之UIView方法调用时机的相关资料...

    windtersharp7642021-05-04
  • IOSiOS 雷达效果实例详解

    iOS 雷达效果实例详解

    这篇文章主要介绍了iOS 雷达效果实例详解的相关资料,需要的朋友可以参考下...

    SimpleWorld11022021-01-28
  • IOSiOS通过逆向理解Block的内存模型

    iOS通过逆向理解Block的内存模型

    自从对 iOS 的逆向初窥门径后,我也经常通过它来分析一些比较大的应用,参考一下这些应用中某些功能的实现。这个探索的过程乐趣多多,不仅能满足自...

    Swiftyper12832021-03-03