(PECL ev >= 0.2.0)
EvPeriodic::__construct — Construye un objeto watcher EvPeriodic
$offset
,$interval
,$reschedule_cb
,$callback
,$data
= null
,$priority
= 0
Construye un objeto watcher EvPeriodic y lo inicia automáticamente. El método EvPeriodic::createStopped() crea un watcher periódico detenido.
offset
interval
reschedule_cb
Función de retrollamada Reschedule. Puede pasarse el valor null
.
Ver los
modos de operación del watcher periódico
callback
data
Datos personalizados para asociar con el watcher.
priority
Ejemplo #1 Temporizador periódico. Utilizando la retrollamada de replanificación
<?php
// Cada 10.5 segundos
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();
?>
Ejemplo #2 Temporizador periódico. Llamado cada 10.5 segundos
<?php
// Cada 10.5 segundos a partir de ahora
$w = new EvPeriodic(fmod(Ev::now(), 10.5), 10.5, NULL, function ($w, $revents) {
echo time(), PHP_EOL;
});
Ev::run();
?>
Ejemplo #3 Watcher cada hora
<?php
$hourly = EvPeriodic(0, 3600, NULL, function () {
echo "una vez por hora\n";
});
?>