erlang timer

erl + c

erl +c 可以禁用系统时间变化所引起的补偿
通常状态下erlang:now/0 是不会把突然的时间变化反应到系统时间的,而是会进行慢性的调整, 这么做是为了保证timer的工作。加入 +c 后, erlang:now/0 会立即反应到系统时间上, 相应的timer的timeout 也可能会出现在错误的时间。

timer 的函数总结

  1. erlang:start_timer(Time, Dest, Msg) -> TimeRef

    Time: 最大的值为2^32 -1 milliseconds, 大概不到50天的时间
    Dest: 必须是本地节点 类型为atom()|pid()
    1. 如果是Dest::atom(), 即便这个Dest 没有绑定一个process 也不会报错, 而是返回正常的TimeRef。但是在进程不存在和进程退出的情况下,该timer 不是立即取消,而是在Time 时间结束的时候才取消的。
    2. 如果是Name::pid(), 如果进程存在或者进程退出,该timer 会立即取消
    这里写图片描述

  2. erlang:send_after/3

    参数和erlang:start_timer 一样, 两者的区别在于当timer timeout 的时候, 发送的消息不同。send_after 发送 Msg, 而start_timer 发送{timeout, TimerRef, Msg}.
    两种消息的区别在于, 当我们cancel 一个timer的时候,我们并不能保证那个Msg 从进程信箱中去除,如果有timerRef , 我们可以参考gen_fsm里cancel_timer的方法, 利用receive..after 0 来匹配TimeRef, 进而去除进程信箱中的Msg, 但是如果是send_after 我们没有办法做到这一点。

  3. erlang:cancel_timer(TimeRef) -> Time|false

    如果是 cancel 一个存在的timer, 返回的是剩余的时间
    如果是 cancel 一个不存在的timer, 返回的是false
    note: 我们并不能保证,我们cancel timer 后, 进程信箱中没有这个 Timer 的 msg
    ( 想要去除 该Msg, 实现参考 gen_fsm:cancel_timer).

  4. timer module 中也有起定时器的操作, 但是这个timer 会有一个独立的进程去处理这个定时器,所以如果有很多进程都用这个module 进行起和删除定时器的话, 效率上自然有问题。

引用:
[1] 坚强 2002 Erlang Timer
[2] mryufeng erlang:send_after和erlang:start_timer的使用解释

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值