atexit

TriggerTek Logo
abcdefghijklmnopqrstuvwxyz_
ATEXIT(3)		  Linux Programmer’s Manual		    ATEXIT(3)



NAME
       atexit  -  register a function to be called at normal program termina-
       tion

SYNOPSIS
       #include <stdlib.h>

       int atexit(void (*function)(void));

DESCRIPTION
       The atexit() function registers the given function  to  be  called  at
       normal  program termination, either via exit(3) or via return from the
       program’s main().  Functions so registered are called in	 the  reverse
       order of their registration; no arguments are passed.

       At  least  ATEXIT_MAX  functions	 can  be registered. This value is at
       least 32. It can be obtained using sysconf(3).

       By a successful call to one of the exec functions,  all	registrations
       are undone.

RETURN VALUE
       The  atexit() function returns the value 0 if successful; otherwise it
       returns a nonzero value.

EXAMPLE
       #include <stdio.h>
       #include <stdlib.h>
       #include <unistd.h>

       void bye(void) {
	       printf("That was all, folks\n");
       }

       int main(){
	       long a;
	       int i;

	       a = sysconf(_SC_ATEXIT_MAX);
	       printf("ATEXIT_MAX = %ld\n", a);

	       i = atexit(bye);
	       if (i != 0) {
		       fprintf(stderr, "cannot set exit function\n");
		       return EXIT_FAILURE;
	       }
	       return EXIT_SUCCESS;
       }

CONFORMING TO
       SVID 3, BSD 4.3, ISO 9899, POSIX 1003.1-2001

SEE ALSO
       exit(3), _exit(3), on_exit(3)



				  2003-11-01			    ATEXIT(3)