C signal handling

Source: Wikipedia, the free encyclopedia.

In the

interactive attention key
on a keyboard).

Standard signals

The C standard defines only 6 signals. They are all defined in signal.h header (csignal header in C++):[1]

  • SIGABRT – "abort", abnormal termination.
  • SIGFPE
    floating point exception
    .
  • SIGILL – "illegal", invalid instruction.
  • SIGINT – "interrupt", interactive attention request sent to the program.
  • SIGSEGV – "
    segmentation violation
    ", invalid memory access.
  • SIGTERM – "terminate", termination request sent to the program.

Additional signals may be specified in the signal.h header by the implementation. For example, Unix and

Unix signal.[2]

Debugging

Handling

A signal can be generated by calling raise() or kill() system calls. raise() sends a signal to the current process, kill() sends a signal to a specific process.

A signal handler is a

function
which is called by the target environment when the corresponding signal occurs. The target environment suspends execution of the program until the signal handler returns or calls longjmp().

Signal handlers can be set with signal() or sigaction(). The behavior of signal() has been changed multiple times across history and its use is discouraged.

SIGSTOP
cannot be caught, blocked or ignored).

If the signal reports an error within the program (and the signal is not asynchronous), the signal handler can terminate by calling abort(), exit(), or longjmp().

Functions

Function Description
raise artificially sends a signal to the calling process
kill artificially sends a signal to a specified process
signal sets the action taken when the program receives a specific signal

Example usage

#include <signal.h>
#include <stdio.h>
#include <stdlib.h>

volatile sig_atomic_t status = 0;

static void catch_function(int signo) {
    status = signo;
}

int main(void) {
    // Set above function as signal handler for the SIGINT signal:
    if (signal(SIGINT, catch_function) == SIG_ERR) {
        fputs("An error occurred while setting a signal handler.\n", stderr);
        return EXIT_FAILURE;
    }
    puts("Raising the interactive attention signal.");
    if (raise(SIGINT)) {
        fputs("Error raising the signal.\n", stderr);
        return EXIT_FAILURE;
    }
    if (status == SIGINT) puts("Interactive attention signal caught.");
    puts("Exiting.");
    return EXIT_SUCCESS;
    // exiting after raising signal
}

See also

  • Unix signal

References

  1. ^ ISO/IEC 9899:1999 specification (PDF). p. 258, § 7.14 Signal handling.
  2. ^ "The Open Group Base Specifications Issue 6 – signal.h – signals". Retrieved 10 January 2012.
  3. ^ https://man7.org/linux/man-pages/man2/signal.2.html Signal(2) manpage