Syntax:
#include <csignal> void ( *signal( int signal, void (* func) (int)) ) (int);
The signal() function sets func to be called when signal is recieved by your program. func can be a custom signal handler, or one of these macros (defined in the csignal header file):
Macro Explanation SIG_DFL default signal handling SIG_IGN ignore the signal
Some basic signals that you can attach a signal handler to are:
Signal Description SIGTERM Generic stop signal that can be caught. SIGINT Interrupt program, normally ctrl-c. SIGQUIT Interrupt program, similar to SIGINT. SIGKILL Stops the program. Cannot be caught. SIGHUP Reports a disconnected terminal.
The return value of signal() is the address of the previously defined function for this signal, or SIG_ERR is there is an error. Example code: The following example uses the signal() function to call an arbitrary number of functions when the user aborts the program. The functions are stored in a vector, and a single “clean-up” function calls each function in that vector of functions when the program is aborted:
void f1() { cout << "calling f1()..." << endl; }
void f2() { cout << "calling f2()..." << endl; }
typedef void(*endFunc)(void); vector<endFunc> endFuncs;
void cleanUp( int dummy ) { for( unsigned int i = 0; i < endFuncs.size(); i++ ) { endFunc f = endFuncs.at(i); (*f)(); } exit(-1); }
int main() {
// connect various signals to our clean-up function signal( SIGTERM, cleanUp ); signal( SIGINT, cleanUp ); signal( SIGQUIT, cleanUp ); signal( SIGHUP, cleanUp );
// add two specific clean-up functions to a list of functions endFuncs.push_back( f1 ); endFuncs.push_back( f2 );
// loop until the user breaks while( 1 );
return 0; }
Related Topics: raise