通过Linux系统调用来完成这个操作,atexit( )
和on_exit( )
。
atexit( )
函数原型:
#include <stdlib.h>
int atexit (void (*function)(void));
示例:
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <signal.h>
static void my_handler (void)
{
printf("my handler!\n");
}
int main()
{
atexit(my_handler); //注册自己的进程结束处理函数
printf("test atexit!\n");
return 0;
}
运行结果:
on_exit( )
使用方法一样。
函数原型:
#include <stdlib.h>
int on_exit(void (*function)(int status, void *arg);
通过信号终止进程时,上面注册的函数执行于signal_handler( )
之后。
示例:
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <signal.h>
static void signal_handler (int signo)
{
if (signo == SIGINT)
{
printf("Caught SIGINT!\n");
exit(EXIT_FAILURE);
}
else if (signo == SIGTERM)
printf("Caught SIGTERM!\n");
else {
fprintf(stderr, "Unexpected signal!\n");
exit(EXIT_FAILURE);
}
exit(EXIT_SUCCESS);
}
static void my_handler (void)
{
printf("my handler!\n");
}
int main()
{
atexit(my_handler);
if (signal (SIGINT, signal_handler) == SIG_ERR)
{
fprintf(stderr, "Cannot handle SIGINT!\n");
exit(EXIT_FAILURE);
}
if (signal (SIGTERM, signal_handler) == SIG_ERR)
{
fprintf(stderr, "Cannot handle SIGTERM!\n");
exit(EXIT_FAILURE);
}
if (signal (SIGPROF, SIG_DFL) == SIG_ERR)
{
fprintf(stderr, "Cannot reset SIGPROF!\n");
exit (EXIT_FAILURE);
}
if (signal (SIGHUP, SIG_IGN) == SIG_ERR) {
fprintf(stderr, "Cannot ignore SIGHUP!\n");
exit (EXIT_FAILURE);
}
for (;;)
pause();
printf("test atexit!\n");
return 0;
}
运行结果(通过ctrl+c
和kill pid
方式终止进程)