如何以精确的时间(即 10 毫秒)定期运行 Erlang 进程 [英] How to run a Erlang Process periodically with Precise Time (i.e. 10ms)
本文介绍了如何以精确的时间(即 10 毫秒)定期运行 Erlang 进程的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我想每 10ms 运行一个周期性的 erlang 进程(基于挂钟时间),10ms 应该尽可能准确;实施它的正确方法应该是什么?
I want to run a periodic erlang process every 10ms (based on wall clock time), the 10ms should be as accurate as possible; what should be the right way to implement it?
推荐答案
如果你想要真正可靠和准确的周期性过程,你应该使用 erlang:monotonic_time/0,1
依赖于实际挂钟时间.如果您使用 Stratus3D 的 回答 你最终会落后.
If you want really reliable and accurate periodic process you should rely on actual wall clock time using erlang:monotonic_time/0,1
. If you use method in Stratus3D's answer you will eventually fall behind.
start_link(Period) when Period > 0, is_integer(Period) ->
gen_server:start_link({local, ?SERVER}, ?MODULE, Period, []).
...
init(Period) ->
StartT = erlang:monotonic_time(millisecond),
self() ! tick,
{ok, {StartT, Period}}.
...
handle_info(tick, {StartT, Period} = S) ->
Next = Period - (erlang:monotonic_time(millisecond)-StartT) rem Period,
_Timer = erlang:send_after(Next, self(), tick),
do_task(),
{noreply, S}.
可以在shell中测试:
You can test in the shell:
spawn(fun() ->
P = 1000,
StartT = erlang:monotonic_time(millisecond),
self() ! tick,
(fun F() ->
receive
tick ->
Next = P - (erlang:monotonic_time(millisecond)-StartT) rem P,
erlang:send_after(Next, self(), tick),
io:format("X~n", []),
F()
end
end)()
end).
这篇关于如何以精确的时间(即 10 毫秒)定期运行 Erlang 进程的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文