# Timer定時器
---
## 定時器原理
Timer定時器是Swoole擴展提供的一個毫秒級定時器,其作用是每隔指定的時間間隔之后執行一次指定的回調函數,以實現定時執行任務的功能。
新版本的Swoole中,定時器是基于epoll方法的timeout機制實現的,不再依賴于單獨的定時線程,準確度更高。同時,Swoole擴展使用最小堆存儲定時器,減少定時器的檢索次數,提高了運行效率。
## 定時器使用
在Swoole中,定時器的函數原型如下:
```php
// function onTimer(int $timer_id, mixed $params = null); // 回調函數的原型
int swoole_timer_tick(int $ms, mixed $callback, mixed $param = null);
int swoole_server::tick(int $ms, mixed $callback, mixed $param = null);
// function onTimer(); // 回調函數的原型(不接受任何參數)
void swoole_timer_after(int $after_time_ms, mixed $callback_function);
void swoole_server::after(int $after_time_ms, mixed $callback_function);
```
tick定時器是一個永久定時器,使用tick方法創建的定時器會一直運行,每隔指定的毫秒數之后執行一次callback函數。在創建定時器的時候,可以通過tick函數的第三個參數,傳遞一些自定義參數到callback回調函數中。另外,也可以使用PHP的閉包(use關鍵字)實現傳參。具體實例如下:
```php
$str = "Say ";
$timer_id = swoole_timer_tick( 1000 , function($timer_id , $params) use ($str) {
echo $str . $params; // 輸出“Say Hello”
} , "Hello" );
```
tick函數會返回定時器的id。當我們不再需要某個定時器的時候,可以根據這個id,調用`swoole_timer_clear`函數刪除定時器。需要注意的是,創建的定時器是不能跨進程的,因此,在一個Worker進程中創建的定時器,也只能在這個Worker進程中刪除,這一點一定要注意(使用`$worker_id`變量來區分Worker進程);
after定時器是一個臨時定時器。使用after方法創建的定時器僅在指定毫秒數之后執行一次callback函數,執行完成后定時器就會刪除。after定時器的回調函數不接受任何參數,可以通過閉包方式傳遞參數,也可以通過類成員變量的方式傳遞。具體實例如下:
```php
class Test
{
private $str = "Say Hello";
public function onAfter()
{
echo $this->str; // 輸出”Say Hello“
}
}
$test = new Test();
swoole_timer_after(1000, array($test, "onAfter"); // 成員變量
swoole_timer_after(2000, function() use($test){ // 閉包
$test->onAfter(); // 輸出”Say Hello“
});
```
- 序章
- 1 環境搭建
- 1.1 環境搭建
- 1.2 搭建Echo服務器
- 2 初識Swoole
- 2.1 Worker進程
- 2.2 TaskWorker進程
- 2.3 Timer定時器
- 2.4 Process進程
- 2.5 Table內存表
- 2.6 多端口監聽
- 2.7 sendfile文件支持
- 2.8 SSL支持
- 3 Swoole協議
- 3.1 EOF協議
- 3.2 固定包頭協議
- 3.3 Http協議
- 3.4 WebSocket協議
- 3.5 MTQQ協議
- 4 Swoole客戶端
- 4.1 Client
- 4.2 異步Http客戶端
- 4.3 異步WebSocket客戶端
- 4.4 異步MySQL客戶端
- 4.5 異步Redis客戶端
- 5 Swoole異步IO
- 5.1 AsyncIO
- 5.2 EventLoop
- 6 Swoole使用
- 7 框架應用
- 7.1 ZPHP
- 7.2 TSF
- 7.3 Hprose
- 7.4 Dora-rpc
- 8 已有框架支持
- 8.1 Yaf
- 8.2 Phalcon
- 8.3 Thinkphp
- 9 項目實戰
- 附錄*配置選項
- 附錄*回調函數
- 附錄*屬性列表
- 附錄*函數列表