У меня есть код пространства пользователя следующим образом,
try
{
some code
...
code that tries accessing forbidden address
...
some code
}
catch (all exceptions)
{
some logs
}
Будет ли ядро отправлять SIGSEGV
сигнал для пользовательского процесса для этого недопустимого доступа и что будет default
поведение (не установлены обработчики сигналов). Будет ли система crash
,
код, который пытается получить доступ к запрещенному адресу
Вы не можете поймать это с C++ exceptions
, Только platform-dependent
решения.
В этом случае исключение не генерируется. Вам нужно установить обработчик сигнала. Заглянуть в сигнал человека как это сделать.
За пример :
#include <stdio.h>
#include <unistd.h>
#include <signal.h>
#include <string.h>
static void hdl (int sig, siginfo_t *siginfo, void *context)
{
printf ("Sending PID: %ld, UID: %ld\n",
(long)siginfo->si_pid, (long)siginfo->si_uid);
}
int main (int argc, char *argv[])
{
struct sigaction act;
memset (&act, '\0', sizeof(act));
/* Use the sa_sigaction field because the handles has two additional parameters */
act.sa_sigaction = &hdl;
/* The SA_SIGINFO flag tells sigaction() to use the sa_sigaction field, not sa_handler. */
act.sa_flags = SA_SIGINFO;
if (sigaction(SIGTERM, &act, NULL) < 0) {
perror ("sigaction");
return 1;
}
while (1)
sleep (10);
return 0;
}