python进程间实时通信_python 进程间通信(二) -- 定时信号 SIGALRM

设置定时 -- settimer

setitimer 方法也是用来定时发出 SIGALRM 信号的,但不同之处在于,他拥有更高的精度,可以定义毫秒级超时setitimer(which, seconds[, interval])

settimer 方法是另一个设置在超时时间后触发 SIGALRM 信号的方法,但与 alarm 不同,他的传入参数 seconds 可以传入小数,从而实现毫秒级超时的设置

which 参数用来指定时间的计算方式,可以选择下列三个枚举中的一个:signal.ITIMER_REAL -- 以系统真是时间来计算,触发 SIGALRM

signal.ITIMER_VIRTUAL -- 以进程用户态花费的时间计算,触发 SIGVTALRM

signal.ITIMER_PROF -- 以进程用户态和内核态所花费的时间计算,触发 SIGPROF

可选的 interval 让你可以为计时器提供一个记号,以便在 getitimer 获取到时明确是哪个计时器触发的信号即将到来

获取当前定时器 -- getitimergetitimer(which)

与 setitimer 相对应,getitimer 用来实现获取定时器情况,他返回一个拥有两个元素的元组,第一个元素是距离定时器下一次触发剩余的超时时间,第二个元素则是创建定时器时可选的 interval 参数的值

which 参数的取值与含义和 setitimer 完全一致

示例 -- 高精度 sleep 实现

import logging

import signal

def alarmhandler(signum, frame):

logging.info('%s handled' % signum)

def sleep(nsec):

signal.pthread_sigmask(signal.SIG_UNBLOCK, {signal.SIGALRM})

signal.signal(signal.SIGALRM, alarmhandler)

signal.setitimer(signal.ITIMER_REAL, nsec)

logging.info(signal.getitimer(signal.ITIMER_REAL))

signal.pause()

if __name__ == '__main__':

logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s: %(message)s')

logging.info('main start sleep')

sleep(1.2)

logging.info('main after sleep')

上面的代码实现了 sleep 1.2 秒的毫秒级超时 sleep,打印出了2019-05-30 08:11:45,580 - INFO: main start sleep

2019-05-30 08:11:45,580 - INFO: (1.199995, 0.0)

2019-05-30 08:11:46,781 - INFO: 14 handled

2019-05-30 08:11:46,781 - INFO: main after sleep

可以看到,超时的时间是非常准确的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值