ualarm()函数调用失败以及浅析

ualarm()函数浅析

函数原型

//come from /usr/include/unistd.h

extern __useconds_t ualarm(__useconds_t __value,__useconds_t __interval)

函数调用成功时,返回原alarm()函数剩余的微秒数,若不存在alarm()函数则返回0,出错的情况下返回-1;

详细描述看man中的介绍。

 

注意看ERRORS:EINVAL 说函数中的两个参数不小于1000000时候,将会出错。所以使用时候注意参数的大小。

看下面本人写的一个测试程序:

#include <unistd.h>
#include <signal.h>
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
void handler(void)
{
 printf("time up\n");
}
int main()
{
 int i=0;
 int rev;
 signal(SIGALRM,(__sighandler_t)handler);
 rev=ualarm(999999,500000);
 if(rev==-1)
 {
  perror("ualarm:");
  exit(1);
 }
 while(1)
 {
  sleep(1);
  printf("i=%d\n",i++);
 }
 return 0;
}

按照程序的本意应该是每秒输出两次time up,输出一次i的数值,真实的结果是这样吗?不是!可以自己测试下看看,把ualarm(999999,500000);中第二个参数改为200000希望每秒能输出5次time up,输出一次i的数值,但你运行的结果发现还是不对,以上的结果都是输出一次time up后,输出一次i的数值。看下面

但是,time up输出的频率确实和ualarm()函数设定的是相吻合,这样我们可以估计一下,使用ualarm()对sleep()函数产生了干扰。就是说在每次软中断后会造成sleep()函数的退出。

原因分析:

以下是我在网上找到的一段话,感觉应该能是这个问题,但是目前还不太确定,因为有人这么说,sleep()与alarm(),本质他们是不同的,sleep是拨了一个临时实时定时器并等待定时器到期,而alarm是用进程唯一的实时定时器来定时唤醒等待信号到来的进程执行。按照上述的见解,那就应该没问题了,暂且把这个问题归为我说的那样吧,要是哪位博友看到了,明白的话,满帆给哦讲解一下,谢谢哈。

关于信号的一些函数:

1.kill产生一个信号:

  extern int kill (__pid_t __pid, int __sig);
  pid>0:将信号发送给进程的pid为pid的进程;
  pid=0:将信号发送给和当前进程在同一个进程组的所有进程;
  pid=-1:将信号发送给系统内的所有进程;
  pid<0:将信号发送给进程组号PGID为pid绝对值的所有进程;
  成功返回0;失败返回值-1.

2.raise自举一个信号:
  extern int raise (int __sig);
  它用来给当前进程发送一个信号,即唤醒一个进程。

3.alarm()定时:
  extern unsigned int alarm(unsigned int __seconds);
  定时产生信号,即在多少时间内产生SIGALRM信号;并不是循环产生,而是每调用一次,产生一次。
  如果sec为0,则取消所有先前发出报警的请求。

4.ualarm()定时:
  extern __usconds_t ualarm(__useconds_t __value, __useconds_t __interval);
  在使当前进程在指定时间(第一个参数)内产生SIGALRM信号,然后每隔指定时间(第二个参数)重复产生SIGALRM信号。

5.信号处理:
  (1)忽略此信号,但有两种信号不能被忽略:SIGKILL和SIGSTOP。
  (2)捕捉信号:
  (3)执行系统默认操作

6.signal安装信号:
  typedef void (*__sighandler_t) (int);
  extern __sighandler_t signal(int __sig, __sighandler_t __handler);
  第二个参数为处理信号的代码入口或下面几个宏:
  #define SIG_ERR ((__sighandler_t) -1);
  #define SIG_DFL  ((__sighandler_t) 0);
  #define SIG_IGN  ((__sighandler_t) 1);

7.sigaction安装信号:
  extern int sigaction (int __sig, struct sigaction * __act, struct sigaction * __oact);
  第一个参数为接收到的信号;
  第二个参数用来指定欲设置的信号处理信息;
  第三个参数将返回执行此程序前此信号处理信息;

 

 

 

 

 

 

 

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值