文章目录
简述
这两个函数与 s e t j m p和l o n g j m p函数非常相似,都是用于程序的非局部转移。而在信号处理程序中,对应使用的就是sigsetjmp和siglongjmp函数。在信号处理程序中,有时需要返回到序的主循环中,而不是从该处理程序返回。为什么不直接使用 s e t j m p和l o n g j m p呢? 因为用l o n g j m p时有一个问题。当捕捉到一个信号时,进入信号捕捉函数,此时当前信号被
自动地加到进程的信号屏蔽字中。这阻止了后来产生的这种信号中断此信号处理程序。如果用
l o n g j m p跳出此信号处理程序,则对此进程的信号屏蔽字会发生什么呢 ?
为了允许两种形式并存,P O S I X . 1并没有说明s e t j m p和l o n g j m p对信号屏蔽字的作用,而是定义了两个新函数s i g s e t j m p和s i g l o n g j m p。在信号处理程序中作非局部转移时应当使用这两个
函数。
int sigsetjmp(sigjmp_buf e n v, int s a v e m a s k) ;
返回:若直接调用则为0,若从s i g l o n g j m p调用返回则为非0
void siglongjmp(sigjmp_buf e n v, int val) ;
这两个函数和s e t j m p,l o n g j m p之间的唯一区别是s i g s e t j m p增加了一个参数。如果s a v e m a s k非0,
则s i g s e t j m p在e n v中保存进程的当前信号屏蔽字。调用 s i g l o n g j m p时,如果带非0 s a v e m a s k的
s i g s e t j m p调用已经保存了e n v,则s i g l o n g j m p从其中恢复保存的信号屏蔽字