В нашем приложении довольно много сбоев, происходящих с пользователями, о которых сообщают crashlytics, однако мы не можем воспроизвести его с нашей стороны. Вот полный отчет о cra sh:
Crashed: com.apple.main-thread
0 TheBarCode 0x100ccc2d8 gmscore::renderer::GLState::Flush() + 16388
1 TheBarCode 0x100cd7630 gmscore::renderer::GLScopedContext::~GLScopedContext() + 31600
2 TheBarCode 0x100d3a314 -[GMSEntityRendererView setFrame:] + 436308
3 TheBarCode 0x100d82578 -[GMSVectorMapView setFrame:] + 184912
4 UIKitCore 0x18f6af878 -[UIView(Geometry) _applyAutoresizingMaskWithOldSuperviewSize:] + 576
5 UIKitCore 0x18f6b0510 -[UIView(Geometry) _resizeWithOldSuperviewSize:] + 236
6 CoreFoundation 0x18b18195c __NSARRAY_IS_CALLING_OUT_TO_A_BLOCK__ + 16
7 CoreFoundation 0x18b084fb0 -[__NSArrayM enumerateObjectsWithOptions:usingBlock:] + 416
8 UIKitCore 0x18f6af5e4 -[UIView(Geometry) resizeSubviewsWithOldSize:] + 156
9 UIKitCore 0x18f6b082c -[UIView(Geometry) setBounds:] + 688
10 UIKitCore 0x18f6b00e0 -[UIView(Geometry) _applyISEngineLayoutValuesToBoundsOnly:] + 528
11 UIKitCore 0x18f6b04ac -[UIView(Geometry) _resizeWithOldSuperviewSize:] + 136
12 CoreFoundation 0x18b18195c __NSARRAY_IS_CALLING_OUT_TO_A_BLOCK__ + 16
13 CoreFoundation 0x18b084fb0 -[__NSArrayM enumerateObjectsWithOptions:usingBlock:] + 416
14 UIKitCore 0x18f6af5e4 -[UIView(Geometry) resizeSubviewsWithOldSize:] + 156
15 UIKitCore 0x18f5f76fc -[UIView(AdditionalLayoutSupport) _is_layout] + 148
16 UIKitCore 0x18f6b7090 -[UIView(Hierarchy) _updateConstraintsAsNecessaryAndApplyLayoutFromEngine] + 1032
17 Gradientable 0x101738798 UIView.swizzled_layoutSubviews() + 50 (Gradientable.swift:50)
18 Gradientable 0x1017388d0 @objc UIView.swizzled_layoutSubviews() + 4359784656 (<compiler-generated>:4359784656)
19 UIKitCore 0x18f6ca17c -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 2140
20 QuartzCore 0x191c322c0 -[CALayer layoutSublayers] + 284
21 QuartzCore 0x191c3843c CA::Layer::layout_if_needed(CA::Transaction*) + 480
22 QuartzCore 0x191c43140 CA::Layer::layout_and_display_if_needed(CA::Transaction*) + 136
23 QuartzCore 0x191b8b884 CA::Context::commit_transaction(CA::Transaction*, double) + 304
24 QuartzCore 0x191bb5574 CA::Transaction::commit() + 676
25 QuartzCore 0x191bb5f68 CA::Transaction::observer_callback(__CFRunLoopObserver*, unsigned long, void*) + 92
26 CoreFoundation 0x18b12be68 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 32
27 CoreFoundation 0x18b126d54 __CFRunLoopDoObservers + 416
28 CoreFoundation 0x18b127320 __CFRunLoopRun + 1308
29 CoreFoundation 0x18b126adc CFRunLoopRunSpecific + 464
30 GraphicsServices 0x1950c7328 GSEventRunModal + 104
31 UIKitCore 0x18f23463c UIApplicationMain + 1936
32 TheBarCode 0x10082756c main + 21 (Preference.swift:21)
33 libdyld.dylib 0x18afb0360 start + 4
Другая странная вещь заключается в том, что мы не получаем никаких дополнительных добавленных (на каком экране это происходит) журналов вместе с cra sh.
Дополнительная информация:
Недавно мы обновили наше приложение для iOS 13 и xcode 11. Таким образом, мы также обновили карты Google iOS SDK до 3.8.0. После обновления мы получаем краткие sh отчеты. В ранее использовавшейся версии мы никогда не сталкивались с этим cra sh, т.е. 2.7.0
. В нашем приложении мы имеем несколько экземпляров GMSMapView
, то есть около 8 экземпляров, встроенных в UIPageViewController
. Ради управления памятью мы сохраняем только видимую версию GMSMapView
и отбрасываем другие экземпляры в viewDidDisappear
методе контроллера представления. Вот код, который мы используем для настройки карты и ее очистки.
func setupMapView() {
let mapView = GMSMapView(frame: CGRect.zero)
mapView.settings.allowScrollGesturesDuringRotateOrZoom = false
if CLLocationManager.authorizationStatus() != .notDetermined {
mapView.settings.myLocationButton = false
mapView.isMyLocationEnabled = true
self.myLocationButtonContainer.isHidden = false
} else {
self.myLocationButtonContainer.isHidden = true
}
self.mapContainer.insertSubview(mapView, at: 0)
mapView.autoPinEdgesToSuperviewEdges()
let iconGenerator = GMUCustomClusterIconGenerator()
let algorithm = GMUNonHierarchicalDistanceBasedAlgorithm()
let renderer = GMUDefaultClusterRenderer(mapView: mapView, clusterIconGenerator: iconGenerator)
renderer.delegate = self
self.clusterManager = GMUClusterManager(map: mapView, algorithm: algorithm, renderer: renderer)
self.clusterManager?.setDelegate(self, mapDelegate: self)
self.mapView = mapView
self.setUpMarkers()
self.restoreMapCameraPosition(animated: false)
}
func clearMapView() {
self.clusterManager?.clearItems()
self.mapView?.clear()
self.mapView?.removeFromSuperview()
self.mapView = nil
self.clusterManager = nil
}
Снимки экрана с данными о сбоях:
Снимок экрана с вкладки данных о сбоях: