require "al_wotker_timer"
タイマーイベントを発生させます。
以下の3つの機能をもちます。
# 繰り返しタイマー # 一秒ごとに、時刻を表示する。 require "al_worker_timer" class Worker1 < AlWorker def initialize2() @timer = Timer.periodic( 1 ) # every 1 sec. @timer.run() { puts Time.now } end end Worker1.new.run
Timer.periodic の第2引数で、最初の起動までの秒数を指定できます。
@timer = Timer.periodic( 60, 5 ) # 5秒後に起動し、その後60秒ごとに起動する
# シングルショットタイマー # 5秒後に時刻を表示して終了する。 require "al_worker_timer" class Worker1 < AlWorker def initialize2() @timer = Timer.singleshot( 5 ) # 5 sec later. @timer.run() { puts Time.now exit } end end Worker1.new.run
# シングルショットタイマー # 次の正時に時刻を表示して終了する。 require "al_worker_timer" class Worker1 < AlWorker def initialize2() t = Time.now @timer = Timer.singleshot( Time.mktime( t.year, t.mon, t.day, t.hour+1 ) ) @timer.run() { puts Time.now exit } end end Worker1.new.run
イベントハンドラは、デフォルトで同期的に呼び出されます。非同期にしたい場合は、mode_sync アトリビュートを変更します。
@timer.mode_sync = :async # 非同期 @timer.mode_sync = :sync # 同期(デフォルト)
タイマーは、任意のタイミングで停止できます。
@timer.stop()