sigsetjmp的用法總結(jié)
相關(guān)函數(shù):longjmp, siglongjmp, setjmp
表頭文件:#include <setjmp.h>
函數(shù)定義:int sigsetjmp(sigjmp_buf env, int savesigs)
函數(shù)說明:sigsetjmp()會保存目前堆棧環(huán)境,然后將目前的地址作一個記號,
而在程序其他地方調(diào)用siglongjmp()時便會直接跳到這個記號位置,然后還原堆棧,繼續(xù)程序的執(zhí)行。
參數(shù)env為用來保存目前堆棧環(huán)境,一般聲明為全局變量
參數(shù)savesigs若為非0則代表擱置的信號集合也會一塊保存
當(dāng)sigsetjmp()返回0時代表已經(jīng)做好記號上,若返回非0則代表由siglongjmp()跳轉(zhuǎn)回來。
返回:若直接調(diào)用則為0,若從siglongjmp調(diào)用返回則為非0
實例:
#include <stdio.h>
#include <signal.h>
#include <setjmp.h>
#include <unistd.h>
#include <sys/time.h>
sigjmp_buf jmp_env;
static void connect_alarm(int)
{
siglongjmp(jmp_env, 1);
}
int main()
{
// 當(dāng)超時時間sec_timeout大于等于運行時間run_time時會跳過printf("running...\n");
int sec_timeout = 3;
int run_time = 2;
printf("timeout = %d, run time = %d\n", sec_timeout, run_time);
if (sec_timeout)
{
// 超過用alarm函數(shù)設(shè)置的時間時產(chǎn)生此信號,調(diào)用connect_alarm函數(shù)
signal(SIGALRM, connect_alarm);
alarm(sec_timeout);
printf("set timeout\n");
if (sigsetjmp(jmp_env, 1))
{
printf("timeout\n");
goto out;
}
}
sleep(run_time);
printf("running...\n");
out:
if (sec_timeout)
{
// 取消先前設(shè)置的鬧鐘
alarm(0);
printf("cancel timeout\n");
}
return 0;
}
程序運行:
當(dāng)ec_timeout = 3, run_time = 2時:
timeout = 3, run_time = 2
set timeout
running...
cancel timeout
當(dāng)ec_timeout = 3, run_time = 4時:
timeout = 3, run_time = 4
set timeout
timeout
cancel timeout
相關(guān)文章
C語言中關(guān)于動態(tài)內(nèi)存分配的詳解
動態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存。棧上分配的內(nèi)存是由系統(tǒng)分配和釋放的,空間有限,在復(fù)合語句或函數(shù)運行結(jié)束后就會被系統(tǒng)自動釋放而堆上分配的內(nèi)存則不會有這個問題。2021-09-09
C語言關(guān)鍵字之a(chǎn)uto register詳解
這篇文章主要為大家介紹了C語言關(guān)鍵字之a(chǎn)uto register,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01

