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


環境: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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM