概述
一直都在使用sem_timedwait 函数用来处理超时等待应答.但是突然发现 没有收到应答.竟然返回了.查了半天竟然是signal(SIGALRM, ....)的原因.man 了一下 sem_timedwait
RETURN VALUE
All of these functions return 0 on success; on error, the value of the
semaphore is left unchanged, -1 is returned, and errno is set to indi‐
cate the error.
ERRORS
EINTR The call was interrupted by a signal handler; see signal(7).这里说了.确实会被唤醒.没办法只能该程序忽略这个信号
int _wait_sem( int sec, char *pack_str_t)
{
struct timespec ts;
int sts;
sem_t *wSem;
wSem = &jf2414_acksem;
p_ack_str = pack_str_t;
ts.tv_sec = time(0) + sec; //important
ts.tv_nsec = 0;
/* Try to lock Semaphore */
sem_init (wSem, 0, 0);//set sem is 0
while ( 1 )
{
sts = sem_timedwait(wSem, &ts);
if(sts == 0)
{
printf("rec ackn");
sem_destroy(wSem);
return 0;
}
else
{
if(errno == ETIMEDOUT)
{
printf("sem timoutn");
sem_destroy(wSem);
return -1;
}
// else if(errno == EINTR)
// {
// continue;//忽略其它signal信号
// }
}
}
}
最后
以上就是安静面包为你收集整理的sem_timedwait 会被signal的信号唤醒及处理办法的全部内容,希望文章能够帮你解决sem_timedwait 会被signal的信号唤醒及处理办法所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复