一、信号相关函数
函数 | 描述 |
---|---|
void *signal(int signo, void (*func)(int)))(int); | 位于:<signal.h>; 功能:给对应信号绑定对应的函数; 返回:成功返回以前的信号处理配置,出错返回SIG_ERR。 1 |
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>; 功能:2; 返回:若休眠到要求的时间,返回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。 ↩︎