summaryrefslogtreecommitdiff
path: root/reference/C/MAN/setjmp.htm
blob: 8c52e966efa66c05582711e2c6d5b268a717a716 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<TITLE>setjmp</TITLE>
<body bgcolor="#ffffcc">
<hr>
<pre>



<h3>SETJMP(3)               Library functions               SETJMP(3)
</h3>

<h3>NAME
</h3>       setjmp - save stack context for non-local goto

<h3>SYNOPSIS
</h3>       #include &lt;setjmp.h&gt;

       int setjmp(jmp_buf env );

<h3>DESCRIPTION
</h3>       setjmp  and  longjmp(3) are useful for dealing with errors
       and interrupts encountered in a low-level subroutine of  a
       program.   setjmp() saves the stack context/environment in
       env for later use by longjmp().  The stack context will be
       invalidated if the function which called setjmp() returns.

<h3>RETURN VALUE
</h3>       It returns the value 0 if returning directly and  non-zero
       when returning from longjmp() using the saved context.

<h3>CONFORMING TO
</h3>       POSIX

<h3>NOTES
</h3>       POSIX does not specify if the signal context will be saved
       or  not.   If  you  want  to  save   signal   masks,   use
       sigsetjmp(3).   setjmp() makes programs hard to understand
       and maintain.  If possible an alternative should be  used.

</pre>
<hr>
<h3>SEE ALSO
</h3><p>
<a href=longjmp.htmlongjmp</a>, 
<a href=sigsetjmp.htm>sigsetjmp</a>, 
<a href=siglongjmp.htm>siglongjmp</a>, 
<pre>



























                        November 25, 1994                       1



</pre>
<P>
<hr>
<p>
<center>
<table border=2 width=80%>
<tr align=center>
<td width=25%>
<a href=../cref.html>Top</a>
</td><td width=25%>
<a href=../master_index.html>Master Index</a>
</td><td width=25%>
<a href=../SYNTAX/keywords.html>Keywords</a>
</td><td width=25%>
<a href=../FUNCTIONS/funcref.htm>Functions</a>
</td>
</tr>
</table>
</center>
<p>
<hr>

This manual page was brought to you by <i>mjl_man V-2.0</i>