pthread多线程时sigalrm和setitimer的使用

目录

 

1、signal

2、signal的注册和捕捉

3、setitimer


1、signal

信号定义在signal.h头文件中,信号名都定义为正整数。
具体的信号名称可以使用kill -l来查看信号的名字以及序号,信号是从1开始编号的,不存在0号信号。kill对于信号0有特殊的应用,kill命令就是发送信号的。

pthread多线程时sigalrm和setitimer的使用_第1张图片

信号的处理有三种方法,分别是:忽略、捕捉和默认动作

  • 忽略信号,大多数信号可以使用这个方式来处理,但是有两种信号不能被忽略(分别是 SIGKILLSIGSTOP)。因为他们向内核和超级用户提供了进程终止和停止的可靠方法,如果忽略了,那么这个进程就变成了没人能管理的的进程,显然是内核设计者不希望看到的场景
  • 捕捉信号,需要告诉内核,用户希望如何处理某一种信号,说白了就是写一个信号处理函数,然后将这个函数告诉内核。当该信号产生时,由内核来调用用户自定义的函数,以此来实现某种信号的处理。
  • 系统默认动作,对于每个信号来说,系统都对应由默认的处理动作,当发生了该信号,系统会自动执行。不过,对系统来说,大部分的处理方式都比较粗暴,就是直接杀死该进程。
    具体的信号默认动作可以使用man 7 signal来查看系统的具体定义。

2、signal的注册和捕捉

线程pthread下,通过signa函数注册两个signal:sigpipe和sigalrm,处理函数分别为sig_ign(忽略)和signa_handle;

pthread多线程时sigalrm和setitimer的使用_第2张图片

pthread多线程时sigalrm和setitimer的使用_第3张图片

运行:

pthread多线程时sigalrm和setitimer的使用_第4张图片

如此,说明线程的alarm被捕捉到了。

那么,这个signal是谁发出来的呢?且待下回分解(其实是还没找到原因)

------------------------------------------------------------------------------------------------------------------

OK,文接上回,信号alarm在这里吗?

NO,这只是信号集里注册了alarm,继续找……,在这里:

就是这个鬼东西在一直产生alarm信号。

3、setitimer

这是一个比较常用的函数,可用来实现延时和定时的功能,

int setitimer(int which, const struct itimerval *new_value, struct itimerval *old_value);
其中which参数表示类型,可选的值有:
ITIMER_REAL:以系统真实的时间来计算,它送出SIGALRM信号。
ITIMER_VIRTUAL:以该进程在用户态下花费的时间来计算,它送出SIGVTALRM信号。
ITIMER_PROF:以该进程在用户态下和内核态下所费的时间来计算,它送出SIGPROF信号。
扒拉个例子做参考吧:

#include
#include
#include
#include
 
int main(void)
{
	struct itimerval setvalue,value;
	setvalue.it_interval.tv_sec=1;
	setvalue.it_interval.tv_usec=0;
	setvalue.it_value.tv_sec=3;
	setvalue.it_value.tv_usec=0;
	setitimer(ITIMER_REAL,&setvalue,NULL);
	
	while(1)
	{
		getitimer(ITIMER_REAL,&value);
		printf("ITIMER_REAL:interval:%ds%dms,remain:%ds%dms\n",
			value.it_interval.tv_sec,value.it_interval.tv_usec,
			value.it_value.tv_sec,value.it_value.tv_usec);
 
		sleep(1);	                            
	}
}
运行输出:

book@book-desktop:~/workspace/zongde/chapter10$ ./a.out 
ITIMER_REAL:interval:3s0ms,remain:2s999998ms
ITIMER_REAL:interval:3s0ms,remain:1s997688ms
ITIMER_REAL:interval:3s0ms,remain:0s991571ms
Alarm clock

 

你可能感兴趣的:(Linux)