Crashlytics Cra sh отчет вокруг Maps SDK, gmscore :: renderer :: GLState :: Flu sh () - PullRequest
3 голосов
/ 24 марта 2020

В нашем приложении довольно много сбоев, происходящих с пользователями, о которых сообщают 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
}

Снимки экрана с данными о сбоях:

enter image description here

Снимок экрана с вкладки данных о сбоях:

enter image description here

1 Ответ

0 голосов
/ 25 марта 2020

Просто понизьте до 3.7.0 iOS Maps SDK.

pod 'GoogleMaps', '~> 3.7.0'
...