signal()
kann auf einigen Betriebssystemen gefährlich sein und ist unter Linux zugunsten von sigaction()
veraltet . "Signal gegen Signalaktion"
Hier ist ein Beispiel, auf das ich kürzlich gestoßen bin ("Tippe auf das Interrupt-Signal") und es modifiziert habe, als ich damit herumgespielt habe.
#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;
}
Für ein voll funktionsfähiges Beispiel können Sie den folgenden Code ausprobieren:
#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;
}
Beispiellauf:
[[email protected]]$ ./a.out
^C
CTRL-C detected
Sie müssen das SIGINT fangen. Etwa so:
void sigint_handler(int sig)
{
[do some cleanup]
signal(SIGINT, SIG_DFL);
kill(getpid(), SIGINT);
}
lädt hier mehr Details