web-dev-qa-db-ja.com

CrashlyticsスレッドはXcode11でビルドされたiOS13でのみクラッシュしました

私のアプリはiOS13でのみクラッシュし、次のコールスタックがあります。

#57. Crashed: com.Twitter.crashlytics.ios.exception
0  myapp                          0x105d6d494 CLSProcessRecordAllThreads + 376 (CLSProcess.c:376)
1  myapp                          0x105d6d87c CLSProcessRecordAllThreads + 407 (CLSProcess.c:407)
2  myapp                          0x105d5d58c CLSHandler + 26 (CLSHandler.m:26)
3  myapp                          0x105d6bab4 __CLSExceptionRecord_block_invoke + 198 (CLSException.mm:198)
4  libdispatch.dylib              0x1be5c100c _dispatch_client_callout + 20
5  libdispatch.dylib              0x1be5cd804 _dispatch_lane_barrier_sync_invoke_and_complete + 60
6  myapp                          0x105d6b55c CLSExceptionRecord + 205 (CLSException.mm:205)
7  myapp                          0x105d6b390 CLSExceptionRecordNSException + 102 (CLSException.mm:102)
8  myapp                          0x105d6afb4 CLSTerminateHandler() + 258 (CLSException.mm:258)
9  libc++abi.dylib                0x1be6d9634 std::__terminate(void (*)()) + 20
10 libc++abi.dylib                0x1be6d8f58 __cxa_get_exception_ptr + 34
11 libc++abi.dylib                0x1be6d8f10 __cxxabiv1::exception_cleanup_func(_Unwind_Reason_Code, _Unwind_Exception*) + 126
12 libobjc.A.dylib                0x1be6341f8 _objc_exception_destructor(void*) + 362
13 Foundation                     0x1bee05434 -[NSISEngine tryToOptimizeReturningMutuallyExclusiveConstraints] + 322
14 Foundation                     0x1bebfeb94 -[NSISEngine _optimizeWithoutRebuilding] + 72
15 Foundation                     0x1bebfeaa8 -[NSISEngine optimize] + 116
16 Foundation                     0x1bebfe718 -[NSISEngine performPendingChangeNotifications] + 116
17 UIKitCore                      0x1c2e447c4 -[UIView(Hierarchy) layoutSubviews] + 316
18 UIKitCore                      0x1c23c6948 -[UIButton layoutSubviews] + 596
19 UIKitCore                      0x1c2e57abc -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 2156
20 libobjc.A.dylib                0x1be62faf0 -[NSObject performSelector:withObject:] + 68
21 QuartzCore                     0x1c53f60f4 -[CALayer layoutSublayers] + 292
22 QuartzCore                     0x1c53f63fc CA::Layer::layout_if_needed(CA::Transaction*) + 484
23 QuartzCore                     0x1c5409964 CA::Layer::layout_and_display_if_needed(CA::Transaction*) + 140
24 QuartzCore                     0x1c534ec1c CA::Context::commit_transaction(CA::Transaction*, double) + 308
25 QuartzCore                     0x1c5379bd8 CA::Transaction::commit() + 684
26 QuartzCore                     0x1c537abc0 CA::Transaction::release_thread(void*) + 232
27 libsystem_pthread.dylib        0x1be62c3c0 _pthread_tsd_cleanup + 584
28 libsystem_pthread.dylib        0x1be624dbc _pthread_exit + 84
29 libsystem_pthread.dylib        0x1be626de8 _pthread_wqthread_legacy_worker_wrap + 98
30 libsystem_pthread.dylib        0x1be626b30 _pthread_wqthread + 424
31 libsystem_pthread.dylib        0x1be62cc78 start_wqthread + 8

--

Fatal Exception: NSInternalInconsistencyException
Modifications to the layout engine must not be performed from a background thread after it has been accessed from the main thread.
0  CoreFoundation                 0x1be919c30 __exceptionPreprocess
1  libobjc.A.dylib                0x1be6340c8 objc_exception_throw
2  Foundation                     0x1bee05434 -[NSISEngine tryToOptimizeReturningMutuallyExclusiveConstraints]
3  Foundation                     0x1bebfeb94 -[NSISEngine _optimizeWithoutRebuilding]
4  Foundation                     0x1bebfeaa8 -[NSISEngine optimize]
5  Foundation                     0x1bebfe718 -[NSISEngine performPendingChangeNotifications]
6  UIKitCore                      0x1c2e447c4 -[UIView(Hierarchy) layoutSubviews]
7  UIKitCore                      0x1c23c6948 -[UIButton layoutSubviews]
8  UIKitCore                      0x1c2e57abc -[UIView(CALayerDelegate) layoutSublayersOfLayer:]
9  libobjc.A.dylib                0x1be62faf0 -[NSObject performSelector:withObject:]
10 QuartzCore                     0x1c53f60f4 -[CALayer layoutSublayers]
11 QuartzCore                     0x1c53f63fc CA::Layer::layout_if_needed(CA::Transaction*)
12 QuartzCore                     0x1c5409964 CA::Layer::layout_and_display_if_needed(CA::Transaction*)
13 QuartzCore                     0x1c534ec1c CA::Context::commit_transaction(CA::Transaction*, double)
14 QuartzCore                     0x1c5379bd8 CA::Transaction::commit()
15 QuartzCore                     0x1c537abc0 CA::Transaction::release_thread(void*)
16 libsystem_pthread.dylib        0x1be62c3c0 _pthread_tsd_cleanup
17 libsystem_pthread.dylib        0x1be624dbc _pthread_exit
18 libsystem_pthread.dylib        0x1be626de8 _pthread_wqthread_legacy_worker_wrap
19 libsystem_pthread.dylib        0x1be626b30 _pthread_wqthread
20 libsystem_pthread.dylib        0x1be62cc78 start_wqthread

私は絶対に何の考えもありません、この問題が何が起こり得るのか、そしてどのように私は再現できますか?ランダムにクラッシュします。私のプロジェクトではCrashlytics v3.14を使用しています。誰かが同じ問題に直面していますか?

17
bemul12

まず最初に、「メインスレッドチェッカー」をオンにすることをお勧めします。Xcodeで、[製品]-> [スキーム]-> [スキームの編集]-> [診断]に移動すると、このウィンドウが表示されます Diagnostics tab もう1つの方法は、Xcodeのブレークポイントセクションに移動し、+記号をクリックしてシンボリックブレークポイントを追加することです。これにより、特定の呼び出しをリッスンし、それに呼び出されているかどうかを確認するための条件を追加できます。メインスレッド。

A symbolic breakpoint

コードでバグを見つけた場合は、ここに投稿してください。アプリで同じクラッシュが発生しているので、バグを見つけるまではこれで終わりです。お役に立てば幸いです。

8

アプリでGoogle広告を有効にしていますか? Google ads sdk のバグか、iOS 13のWebKit SDK実装のバグの可能性があります(コメントできないので、これを回答として投稿します)。

これの便乗-上記のリンクされたスレッドを読んで、2019年11月19日現在のGoogle広告チームの「公式」ソリューションは、uiwebviewではなくwkwebviewを使用するように次のキー/ペアを含めるようにアプリのplistを変更することです。

<key>gad_preferred_webview</key>
<string>wkwebview</string>

出典: https://groups.google.com/forum/#!category-topic/google-admob-ads-sdk/ios/I4EEWrPPbSc

16
own2pwn

この問題は、Google広告SDK(7.5X.X + iOS13)が原因である可能性があります。この thread が見つかりました。

Google広告チームの提案に従い、デベロッパーはInfo.plistファイルの以下のキーペア値を使用しようとしました。

<key>gad_preferred_webview</key>
<string>wkwebview</string>

これによりクラッシュが減少しましたが、これは別のフリーズの問題を引き起こしています(100%のCPU使用率)。

最近、Googleは7.55.0をリリースしました。

Removed all references to UIWebView. UIWebView is no longer supported.

google広告SDKを7.55.0に更新してみてください

5
Aryan

スレッドのスタックトレースを表示するには、Crashlyticsがクラッシュ後にコードを実行する必要があります。このコードはアプリのスレッドの1つで実行されているため、Crashlyticsは常にこのプロセスの一部として、自身の実行に関する情報をキャプチャします。 「CLSProcessRecordAllThreads」関数を実行するスレッドが常に表示されます。実際、インライン化と呼ばれるコンパイラーの最適化により、複数回表示されます。 enter image description here 例外により、複雑さがさらに増します。 Objective-CまたはC++の例外がキャッチされなくなると、Crashlyticsはアプリの終了を許可する前にそれに関する情報を記録します。これが発生した場合、CLSProcessRecordAllThreads関数は、例外をスローしたスレッドで実行する必要があります。つまり、例外の場合、「クラッシュ」スレッドは常にCrashlyticsコードを実行しているように見えます。これは正常であり、例外時にスタックトレースをキャプチャして表示する方法の単なるアーティファクトです。

2
Zubair