NAME
sigevent - 与异步通知控制相关的结构体。
SYNOPSIS
#include <signal.h>
union sigval {
int sival_int;
void *sival_ptr;
};
struct sigevent {
int sigev_notify; /* 通知方式 */
int sigev_signo; /* 通知信号 */
union sigval sigev_value; /* 伴随通知所传递的数据 */
void (*sigev_notify_function) (union sigval);
/* 通知方式设置为"线程通知" (SIGEV_THREAD)时新线程的线程函数 */
void *sigev_notify_attributes;
/* 通知方式设置为"线程通知" (SIGEV_THREAD)时新线程的属性 */
pid_t sigev_notify_thread_id;
/* 通知方式为SIGEV_THREAD_ID时,接收信号的线程的pid */
};
DESCRIPTION
sigevent结构被各种API用来描述通知进程事件的方式(例如,异步请求的完成、计时器的过期或消息的到达)。SYNOPSIS中显示的定义是对sigevent结构中的一些字段的大致描绘(并不是严格地表述),那些字段有些有可能被定义为联合体,所以编程时应该只使用那些与sigev_notify
中指定的值相关的字段。比如,sigev_notify
设置为SIGEV_SIGNAL
,那就不要对sigev_notify_function
、sigev_notify_attributes
进行赋值了。
sigev_notify
字段定义了通知的方式,可取的值有以下几种:
SIGEV_NONE
:不通知。当事件发生时不做任何操作。SIGEV_SIGNAL
:通过发送sigev_signo
所指定的信号的方式通知进程事件(比如定时器到期)已经发生。如果这个信号被由指定了flagSA_SIGINFO
的sigaction(2)
注册的信号处理函数所捕获,信号处理函数的参数siginfo_t的以下三个字段会被填充为:
si_code 该字段取决于产生通知事件的API。比如,这个信号是被posix timer定时器到期所产生的,那么就会被设置为SI_TIMER。
si_signo 该字段被设置为信号值(即sigevent结构体中sigev_signo
所指定的值)
si_value 该字段被设置为sigevent结构体中sigev_value
的值。
其他siginfo_t字段也可能会由于API的不同而被设置。
sigwaitinfo(2)
接口也是可以获取到上述各个字段的信息的。SIGEV_THREAD
:通过调用sigev_notify_function
的方式通知进程事件(比如定时器到期)已经发生,就“好像”它是一个新开启的线程一样。(这里的实现可能包括:每个计时器通知都可能导致创建一个新线程,或者创建一个线程来接收所有通知。)调用函数时,sigev_value
是它的唯一参数。如果sigev_notify_attributes
不是NULL,它应该指向一个pthread_attr_t结构体,该结构体定义了新线程的属性- SIGEV_THREAD_ID(linux特有):目前只被posix timer使用,详见
timer_create(2)
SEE ALSO
timer_create(2), aio_fsync(3), aio_read(3), aio_write(3), getaddrinfo_a(3), lio_listio(3), mq_notify(3), aio(7), pthreads(7)