|
longjmp, siglongjmp — nonlocal jump to a saved stack context
#include <setjmp.h>
void
longjmp( |
jmp_buf env, |
int val) ; |
void
siglongjmp( |
sigjmp_buf env, |
int val) ; |
Note | |||
---|---|---|---|
|
longjmp
() and setjmp(3) are useful for
dealing with errors and interrupts encountered in a low-level
subroutine of a program. longjmp
() restores the environment saved by
the last call of setjmp(3) with the
corresponding env
argument. After longjmp
() is
completed, program execution continues as if the
corresponding call of setjmp(3) had just returned
the value val
.
longjmp
() cannot cause 0 to be
returned. If longjmp
() is
invoked with a second argument of 0, 1 will be returned
instead.
siglongjmp
() is similar to
longjmp
() except for the type
of its env
argument.
If, and only if, the sigsetjmp(3) call that set
this env
used a
nonzero savesigs
flag, siglongjmp
() also
restores the signal mask that was saved by sigsetjmp(3).
POSIX does not specify whether longjmp
() will restore the signal context
(see setjmp(3) for some more
details). If you want to portably save and restore signal
masks, use sigsetjmp(3) and
siglongjmp
().
The values of automatic variables are unspecified after a
call to longjmp
() if they meet
all the following criteria:
Analogous remarks apply for siglongjmp
().
longjmp
() and siglongjmp
() make programs hard to
understand and maintain. If possible an alternative should be
used.
This page is part of release 3.52 of the Linux man-pages
project. A
description of the project, and information about reporting
bugs, can be found at
http://www.kernel.org/doc/man−pages/.
Written by Michael Haardt, Fri Nov 25 14:51:42 MET 1994 %%%LICENSE_START(GPLv2+_DOC_FULL) This is free documentation; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. The GNU General Public License's references to "object code" and "executables" are to be interpreted as the output of any document formatting or typesetting system, including intermediate and printed output. This manual is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this manual; if not, see <http://www.gnu.org/licenses/>. %%%LICENSE_END Added siglongjmp, Sun Mar 2 22:03:05 EST 1997, jrvvanzandt.mv.com Modifications, Sun Feb 26 14:39:45 1995, faithcs.unc.edu " |