signal()
può essere pericoloso su alcuni sistemi operativi ed è deprecato su Linux a favore di sigaction()
. "segnale contro sigazione"
Ecco un esempio in cui mi sono imbattuto di recente ("Tocca il segnale di interruzione") e modificato mentre ci giocavo.
#include<stdio.h>
#include<unistd.h>
#include<signal.h>
#include<string.h>
struct sigaction old_action;
void sigint_handler(int sig_no)
{
printf("CTRL-C pressed\n");
sigaction(SIGINT, &old_action, NULL);
kill(0, SIGINT);
}
int main()
{
struct sigaction action;
memset(&action, 0, sizeof(action));
action.sa_handler = &sigint_handler;
sigaction(SIGINT, &action, &old_action);
pause();
return 0;
}
Per un esempio funzionante completo puoi provare il seguente codice:
#include <signal.h>
#include <stdio.h>
#include <stdbool.h>
volatile bool STOP = false;
void sigint_handler(int sig);
int main() {
signal(SIGINT, sigint_handler);
while(true) {
if (STOP) {
break;
}
}
return 0;
}
void sigint_handler(int sig) {
printf("\nCTRL-C detected\n");
STOP = true;
}
Esecuzione di esempio:
[[email protected]]$ ./a.out
^C
CTRL-C detected
Devi prendere il SIGINT. Qualcosa del genere:
void sigint_handler(int sig)
{
[do some cleanup]
signal(SIGINT, SIG_DFL);
kill(getpid(), SIGINT);
}
carica più dettagli qui