文章目录
在本篇博文中,您将学到如下内容:
- 如何在 Xcode 中正确打开真机设备上的 ips.synced 崩溃日志文件?
- 如何通过真机崩溃日志快速定位错误代码?
- 导致上述多线程同步问题的根本原因是什么?
- 如何优雅的用新 async/await Actor 并发机制解决上述问题?
问题现象
现今,App 的性能大幅提升得益于强大处理器的多线程并发模型。不过,不恰当的并发同步代码也会导致诸多问题,严重的话可能直接引起 App 崩溃。
在 App 中我们尝试通过多线程并发获取 Web 页面中图片的大小,但由于线程间错误的同步代码导致多调用了 DispatchGroup.leave() 方法一次,引起了 App 的崩溃:
libdispatch.dylib: BUG IN CLIENT OF LIBDISPATCH: Unbalanced call to dispatch_group_leave()
请系好安全带,本次旅行将精彩纷呈。Let’s Go!!! 😉
问题分析
1. 失踪的真机崩溃日志
当 App 在真机