2

CrashReporterの情報は次のとおりです。

Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0:
0   libsystem_kernel.dylib          0x347c2848 __kill + 8
1   [My Application]                0x0002ec44 fatal_signal_handler (PLCrashSignalHandler.m:98)
2   libsystem_c.dylib               0x37518522 _sigtramp + 42
3   [My Application]                0x0003040a uncaught_exception_handler (PLCrashReporter.m:136)
4   CoreFoundation                  0x37663984 __handleUncaughtException + 68
5   libobjc.A.dylib                 0x334082ca _objc_terminate + 122
6   libc++abi.dylib                 0x37f473be safe_handler_caller(void (*)()) + 70
7   libc++abi.dylib                 0x37f4744a std::terminate() + 14
8   libc++abi.dylib                 0x37f4881e __cxa_rethrow + 82
9   libobjc.A.dylib                 0x3340822e objc_exception_rethrow + 6
10  CoreFoundation                  0x375b9556 CFRunLoopRunSpecific + 398
11  CoreFoundation                  0x375b93b6 CFRunLoopRunInMode + 98
12  UIKit                           0x3354dda4 -[UIApplication _run] + 544
13  UIKit                           0x3354b05a UIApplicationMain + 1074
14  [My Application]                0x00002a9a main (main.m:54)
15  [My Application]                0x00002a58 0x1000 + 6744

アプリを削除してから、更新されたバージョンを最初からダウンロードすると、正常に動作します...

4

1 に答える 1

3

これは、Objective-C 例外がスローされ、runloop によってキャッチされ、再スローされ、バックトレースが失われることによって発生します。

PLCrashReporter/HockeyApp を変更せずにこれをデバッグするには、NSSetUncaughtExceptionHandler()を介して独自の例外ハンドラーを登録し、提供されたスタック トレースを ([- NSException callStackReturnAddresses ] を参照) を介してログに記録します。結果を手動でシンボル化する必要があります。

このクラスのバグのより一般的な解決策として、PLCrashReporter トランクを使用して元の例外のバックトレースを取得できる場合があります。これにより、例外の元のバックトレースがクラッシュ レポートに個別に記録されます。

ただし、追加のスタック トレースの記録をサポートするには、HockeyApp クライアントを最小限に変更する必要があります。PLCrashReporter に含まれるテキスト フォーマッタを例として使用できます。これは、この追加のスタック トレースを追加の名前付き疑似スレッドとしてフォーマットします。

于 2011-09-21T19:26:03.997 に答える