Swoole學習(六)Swoole之定時器的建立與清除

OldBoy~發表於2018-01-15

環境:Centos6.4,PHP環境:PHP7,Swoole2.1(在指定的時間後執行函式,需要1.7.7或更高版本)

<?php
//---------------------------------------------------swoole_timer_tick--------------------------------------------------//
//設定一個間隔時鐘定時器,與after定時器不同的是tick定時器會持續觸發,直到呼叫swoole_timer_clear清除。
//int swoole_timer_tick(int $ms, callable $callback, mixed $user_param);
//$ms 指定時間,單位為毫秒
//$callback_function 時間到期後所執行的函式,必須是可以呼叫的。
//$user_param 使用者引數, 該引數會被傳遞到$callback_function中. 如果有多個引數可以使用陣列形式. 也可以使用匿名函式的use語法傳遞引數到回撥函式中
//定時器僅在當前程式空間內有效
//定時器是純非同步實現的,不能與阻塞IO的函式一起使用,否則定時器的執行時間會發生錯亂
//$ms 最大不得超過 86400000
//tick定時器在1.7.14以上版本可用
//定時器在執行的過程中可能會產生微小的偏差,請勿基於定時器實現精確時間計算
swoole_timer_tick(2000, function ($timer_id) {  //每隔2000ms觸發一次
    echo "tick-2000ms\n";

});
//---------------------------------------------------swoole_timer_after--------------------------------------------------//
//swoole_timer_after函式是一個一次性定時器,執行完成後就會銷燬。此函式與PHP標準庫提供的sleep函式不同,after是非阻塞的。而sleep呼叫後會導致當前的程式進入阻塞,將無法處理新的請求。

//執行成功返回定時器ID,若取消定時器,可呼叫 swoole_timer_clear
//int swoole_timer_after(int $after_time_ms, mixed $callback_function, mixed $user_param);
//$after_time_ms 指定時間,單位為毫秒,最大不得超過 86400000
//$callback_function 時間到期後所執行的函式,必須是可以呼叫的。
//$user_param 使用者引數, 該引數會被傳遞到$callback_function中. 如果有多個引數可以使用陣列形式. 也可以使用匿名函式的use語法傳遞引數到回撥函式中

swoole_timer_after(3000, function () {  //3000ms後執行此函式
    echo "after 3000ms.\n";
});

//--------------------------------------------------swoole_timer_clear---------------------------------------------------//
//清除定時器
//使用定時器ID來刪除定時器。
//bool swoole_timer_clear(int $timer_id)
//$timer_id,定時器ID,呼叫swoole_timer_tick、swoole_timer_after後會返回一個整數的ID
//swoole_timer_clear不能用於清除其他程式的定時器,只作用於當前程式
$timer = swoole_timer_after(1000, function(){
    echo "timeout\n";
});

var_dump(swoole_timer_clear($timer));
var_dump($timer);

// 輸出:bool(true) int(1)
// 不輸出:timeout

 

相關文章