2000-02-18 03:39:52 +08:00
|
|
|
@node Signals
|
|
|
|
@chapter Signal Handling (@file{signal.h})
|
|
|
|
|
|
|
|
A @dfn{signal} is an event that interrupts the normal flow of control
|
|
|
|
in your program. Your operating environment normally defines the full
|
|
|
|
set of signals available (see @file{sys/signal.h}), as well as the
|
|
|
|
default means of dealing with them---typically, either printing an
|
|
|
|
error message and aborting your program, or ignoring the signal.
|
|
|
|
|
|
|
|
All systems support at least the following signals:
|
|
|
|
@table @code
|
|
|
|
@item SIGABRT
|
2015-06-23 19:56:24 +08:00
|
|
|
Abnormal termination of a program; raised by the @code{abort} function.
|
2000-02-18 03:39:52 +08:00
|
|
|
|
|
|
|
@item SIGFPE
|
|
|
|
A domain error in arithmetic, such as overflow, or division by zero.
|
|
|
|
|
|
|
|
@item SIGILL
|
|
|
|
Attempt to execute as a function data that is not executable.
|
|
|
|
|
|
|
|
@item SIGINT
|
|
|
|
Interrupt; an interactive attention signal.
|
|
|
|
|
|
|
|
@item SIGSEGV
|
|
|
|
An attempt to access a memory location that is not available.
|
|
|
|
|
|
|
|
@item SIGTERM
|
|
|
|
A request that your program end execution.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
Two functions are available for dealing with asynchronous
|
|
|
|
signals---one to allow your program to send signals to itself (this is
|
|
|
|
called @dfn{raising} a signal), and one to specify subroutines (called
|
|
|
|
@dfn{handlers} to handle particular signals that you anticipate may
|
|
|
|
occur---whether raised by your own program or the operating environment.
|
|
|
|
|
|
|
|
To support these functions, @file{signal.h} defines three macros:
|
|
|
|
|
|
|
|
@table @code
|
|
|
|
@item SIG_DFL
|
|
|
|
Used with the @code{signal} function in place of a pointer to a
|
|
|
|
handler subroutine, to select the operating environment's default
|
|
|
|
handling of a signal.
|
|
|
|
|
|
|
|
@item SIG_IGN
|
|
|
|
Used with the @code{signal} function in place of a pointer to a
|
|
|
|
handler, to ignore a particular signal.
|
|
|
|
|
|
|
|
@item SIG_ERR
|
|
|
|
Returned by the @code{signal} function in place of a pointer to a
|
|
|
|
handler, to indicate that your request to set up a handler could not
|
|
|
|
be honored for some reason.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
@file{signal.h} also defines an integral type, @code{sig_atomic_t}.
|
|
|
|
This type is not used in any function declarations; it exists only to
|
|
|
|
allow your signal handlers to declare a static storage location where
|
|
|
|
they may store a signal value. (Static storage is not otherwise
|
|
|
|
reliable from signal handlers.)
|
|
|
|
|
|
|
|
@menu
|
2011-05-04 19:26:22 +08:00
|
|
|
* psignal:: Print a signal message to standard error
|
2000-02-18 03:39:52 +08:00
|
|
|
* raise:: Send a signal
|
|
|
|
* signal:: Specify handler subroutine for a signal
|
|
|
|
@end menu
|
|
|
|
|
2011-05-04 19:26:22 +08:00
|
|
|
@page
|
|
|
|
@include signal/psignal.def
|
|
|
|
|
2000-02-18 03:39:52 +08:00
|
|
|
@page
|
|
|
|
@include signal/raise.def
|
|
|
|
|
|
|
|
@page
|
|
|
|
@include signal/signal.def
|