setjmp

Autres langues

Langue: fr

Version: 2 mars 1997 (mandriva - 01/05/08)

Section: 3 (Bibliothèques de fonctions)

NOM

setjmp, sigsetjmp - Sauver le contexte de pile pour un saut non-local

SYNOPSIS

#include <setjmp.h>
 int setjmp (jmp_buf env);
 int sigsetjmp (sigjmp_buf env, int savesigs);
 

DESCRIPTION

Les fonctions setjmp() et longjmp(3) sont utiles pour gérer les erreurs et les interruptions rencontrées dans des routines bas-niveau. setjmp() sauvegarde le contexte de pile et d'environnement dans env afin de l'utiliser ultérieurement avec longjmp(3). Le contexte de pile sera invalide si la fonction qui appelle setjmp() se termine.

sigsetjmp() est semblable à setjmp(). Si savesigs est non-nul, l'ensemble des signaux bloqués est sauvegardé dans env, et sera rétabli lorsque siglongjmp(3) sera invoquée avec ce contexte env.

VALEUR RENVOYÉE

setjmp() et sigsetjmp() renvoient 0 lorsqu'elles reviennent directement, et une valeur non-nulle si elles reviennent à travers un appel à longjmp(3) ou siglongjmp(3) utilisant le contexte sauvegardé.

CONFORMITÉ

C89, C99, et POSIX.1-2001 spécifient setjmp(). POSIX.1-2001 spécifie sigsetjmp().

NOTES

POSIX ne précise pas si setjmp() sauve ou non le contexte de signaux. (Dans System V ce n'est pas le cas, dans BSD si, mais il existe une fonction _setjmp() qui ne le fait pas). Si vous voulez sauver le masque de signaux, utilisez sigsetjmp().

setjmp() et sigsetjmp() rendent les programmes difficiles à comprendre et à maintenir. Si possible, essayez d'utiliser une autre méthode.

VOIR AUSSI

longjmp(3), siglongjmp(3)

TRADUCTION

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 7 novembre 1996 et révisée le 19 novembre 2007.

L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 3 setjmp ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.