IOS用に独自のシグナルとキャッチされない例外ハンドラーを構築しようとしています。これを行うには、次の2つの関数を使用します。
NSSetUncaughtExceptionHandler(/*handler*/);
そして
signal(/*signal const*/, /*signal handler*/);
私の問題は、EXC_BAD_ACCESS信号で動作させることができないことです。 EXC_BAD_ACCESSをキャッチするための信号定数(SIGABRT、SIGBUSなど)はありますか?いいえの場合、どうすれば処理できますか?一部のクラッシュ分析ツール(lika PLCrashReporter、Crashlyticsなど)はそれを追跡できます...
EXC_BAD_ACCESS
は例外を生成しないため、最初の関数はケースで機能しません。シグナルSIGSEGV
またはSIGBUS
を生成します。
未処理の例外とシグナルの処理 by Cocoa withLoveを参照してください。
更新
LLDBのソースコードを確認しました。それは可能性があります TARGET_EXC_BAD_ACCESS
= 0x91。
RNBRemote.hの場合:
/* We translate the /usr/include/mach/exception_types.h exception types
(e.g. EXC_BAD_ACCESS) to the fake BSD signal numbers that gdb uses
in include/gdb/signals.h (e.g. TARGET_EXC_BAD_ACCESS). These hard
coded values for TARGET_EXC_BAD_ACCESS et al must match the gdb
values in its include/gdb/signals.h. */
#define TARGET_EXC_BAD_ACCESS 0x91
#define TARGET_EXC_BAD_INSTRUCTION 0x92
#define TARGET_EXC_ARITHMETIC 0x93
#define TARGET_EXC_EMULATION 0x94
#define TARGET_EXC_SOFTWARE 0x95
#define TARGET_EXC_BREAKPOINT 0x96
およびRNBRemote.cpp:
// Translate any mach exceptions to gdb versions, unless they are
// common exceptions like a breakpoint or a soft signal.
switch (tid_stop_info.details.exception.type)
{
default: signum = 0; break;
case EXC_BREAKPOINT: signum = SIGTRAP; break;
case EXC_BAD_ACCESS: signum = TARGET_EXC_BAD_ACCESS; break;
case EXC_BAD_INSTRUCTION: signum = TARGET_EXC_BAD_INSTRUCTION; break;
case EXC_ARITHMETIC: signum = TARGET_EXC_ARITHMETIC; break;
case EXC_EMULATION: signum = TARGET_EXC_EMULATION; break;
case EXC_SOFTWARE:
if (tid_stop_info.details.exception.data_count == 2 &&
tid_stop_info.details.exception.data[0] == EXC_SOFT_SIGNAL)
signum = tid_stop_info.details.exception.data[1];
else
signum = TARGET_EXC_SOFTWARE;
break;
}