EvPeriodic::__construct

(PECL ev >= 0.2.0)
Constructs EvPeriodic watcher object
public EvPeriodic::__construct ( double $offset , string $interval , callable $reschedule_cb , callable $callback [, mixed $data = NULL [, int $priority = 0 ]] )

Constructs EvPeriodic watcher object and starts it automatically. EvPeriodic::createStopped() method creates stopped periodic watcher.

Parameters:
offset

See Periodic watcher operation modes

interval

See Periodic watcher operation modes

reschedule_cb

Reschedule callback. You can pass NULL. See Periodic watcher operation modes

callback

See Watcher callbacks .

data

Custom data associated with the watcher.

priority

Watcher priority

Returns:

Returns EvPeriodic object on success.

Examples:
Periodic timer. Use reschedule callback
1
2
3
4
5
6
7
8
9
10
11
12
<?php
// Tick each 10.5 seconds
 
function reschedule_cb ($watcher$now) {
 return $now + (10.5. - fmod($now, 10.5));
}
 
$w new EvPeriodic(0., 0., "reschedule_cb"function ($w$revents) {
 echo time(), PHP_EOL;
});
Ev::run();
?>
Periodic timer. Tick every 10.5 seconds starting at now
1
2
3
4
5
6
7
<?php
// Tick every 10.5 seconds starting at now
$w new EvPeriodic(fmod(Ev::now(), 10.5), 10.5, NULL, function ($w$revents) {
 echo time(), PHP_EOL;
});
Ev::run();
?>
Hourly watcher
1
2
3
4
5
<?php
$hourly = EvPeriodic(0, 3600, NULL, function () {
 echo "once per hour\n";
};
?>
See also:

Periodic watcher operation modes -

EvTimer -

EvPeriodic::createStopped() -

doc_php
2025-01-10 15:47:30
Comments
Leave a Comment

Please login to continue.