一、信号相关函数
函数描述
void *signal(int signo, void (*func)(int)))(int);位于:<signal.h>;功能:给对应信号绑定对应的函数;返回:成功返回以前的信号处理配置,出错返回SIG_ERR。int kill(pid_t pid, int signo);位于:<signal.h>;功能:将信号发送给进程或进程组;返回:成功返回0,出错返回-1。int raise(int signo);位于:<signal.h>;功能:进程向自身发送信号;返回:成功返回0,出错返回-1。unsigned int alarm(unsigned int seconds);位于:<signal.h>;功能:设置一个定时器,在将来的某个时刻定时器会超时。当定时器超时时,产生SIGALRM信号。如果忽略或不捕捉此信号,则其默认动作是终止调用改alarm函数进程;返回:0或以前设置的闹钟时间的余留秒数。unsigned int alarm(unsigned int seconds);位于:<signal.h>;功能:使调用进程挂起直至捕捉到一个信号;返回:-1,errno设置为EINTR。int sigemptyset(sigset_t *set);位于:<signal.h>;功能:初始化有set指向的信号集,清除其中所有信号;返回:成功返回0,出错返回-1。int sigfillset(sigset_t *set);位于:<signal.h>;功能:初始化有set指向的信号集,使其包含所有的信号;返回:成功返回0,出错返回-1。int sigaddset(sigset_t *set, int signo);位于:<signal.h>;功能:将一个信号添加到已有的信号集中;返回:成功返回0,出错返回-1。int sigdelset(sigset_t *set, int signo);位于:<signal.h>;功能:从信号集中删除一个信号;返回:成功返回0,出错返回-1。int sigismember(const sigset_t *set, int signo);位于:<signal.h>;功能:测试一个指定位;返回:若真,返回1;若假,返回0。int sigprocmask(int how, const sigset_t *set, const sigset_t *oset);位于:<signal.h>;功能:检查或更改,或同时进行检查和更改进程的信号屏蔽字;返回:成功返回0,出错返回-1。int sigpending(sigset_t *set);位于:<signal.h>;功能:返回一个信号集,对于调用进程而言,其中的各信号是阻塞不能传递的,因而也一定是当前未决的。改信号集通过set参数返回;返回:成功返回0,出错返回-1。int sugaction(int signo, struct sigaction act, struct sigaction oact);位于:<signal.h>;功能:检查或修改与指定信号相关联的处理动作;返回:成功返回0,出错返回-1。int sigsetjmp(sigjmp_buf env, int savemask);位于:<setjmp.h>;功能:会保存目前堆栈环境,然后将目前的地址作一个记号,而在程序其他地方调用siglongjmp()时便会直接跳到这个记号位置,然后还原堆栈,继续程序的执行;返回:若直接调用,返回0;若从siglongjmp调用,则返回非0。int siglongjmp(sigjmp_buf env, int val);位于:<setjmp.h>;功能:调转到sigsetjmp函数指定的地方。int sigsuspend(const sigset_t *sigmask);位于:<signal.h>;功能:在一个原子操作中先恢复信号屏蔽字,然后使进程休眠;返回:-1,并将errno设置为EINTR。int abort(void);位于:<stdlib.h>;功能:使程序异常终止。unsigned sleep(unsigned int seconds);位于:<time.h>;功能:使调用进程挂起seconds秒,或者调用进程捕捉到一个信号并从信号处理程序返回;返回:0或未休眠完的秒数。unsigned nanosleep(const struct timespec *reqtp, struct timespec *remtp);位于:<time.h>;功能:;返回:若休眠到要求的时间,返回0;若出错,返回-1。int clock_nanosleep(clockid_t clock_id, int flags, const struct timespec *reqtp, struct timespect *remtp);位于:<time.h>;功能:休眠指定的时间;返回:若休眠要求的时间,返回0;若出错,返货错误码。int sigqueue(pid_t pid, int signo, const union sigval value);位于:<signal.h>;功能:把信号发给指定进程;返回:成功返回0,出错返回-1。
#include <stdio.h>
#include <signal.h>
void sig_usr(int signo
) {
printf("signo: %d", signo
);
}
int main(int argc
, char *argv
[]) {
signal(SIGKILL
, sig_usr
);
return 0;
}
signo 参数可以是<signum.h> 头文件中定义的宏,从SIGHUP开始到SIGUNUSED之间的值;func的值是常量 SIG_IGN、SIG_DFL 或当接到此信号要调用的函数的地址。指定 SIG_IGN则向内核表示忽略此信号(SIGKILL和SIGSTOP不能忽略)。如果指定SIG_DFL ,则表示接到此信号后的动作是系统默认动作。 ↩︎
挂起调用进程,直达要求的时间已经超出或某个信号中断了该函数。eqtp参数用秒和纳秒指定了需要休眠的时间长度。如果某个信号中断了休眠间隔,进程并没有终止,remtp参数指向的timespec结构就会被设置为未休眠完的时间长度。如果对未休眠完的时间并不感兴趣,可以把改参数设置为NULL。 ↩︎