(PECL ev >= 0.2.0)
Representa un bucle de eventos que siempre es distinto del bucle por defecto. A diferencia del bucle por defecto, no puede gestionar los watchers EvChild.
Al utilizar hilos, se debe crear un bucle por hilo, y utilizar el bucle por defecto en el hilo padre.
El bucle de eventos por defecto es inicializado automáticamente por Ev. Es accesible a través de los métodos de la clase Ev o mediante el método EvLoop::defaultLoop().
$flags
= ?,$data
= NULL
,$io_interval
= 0.0
,$timeout_interval
= 0.0
$pid
,$trace
,$callback
,$data
= ?,$priority
= ?$flags
= Ev::FLAG_AUTO
,$data
= NULL
,$io_interval
= 0.
,$timeout_interval
= 0.
$other
,$callback
= ?,$data
= ?,$priority
= ?$fd
,$events
,$callback
,$data
= null
,$priority
= 0
$offset
,$interval
,$callback
,$data
= null
,$priority
= 0
$signum
,$callback
,$data
= null
,$priority
= 0
$path
,$interval
,$callback
,$data
= null
,$priority
= 0
Datos personalizados para adjuntar al bucle
Solo lectura. Los flags del backend que indican el backend de eventos en uso.
Solo lectura.
true
si es el bucle de eventos por defecto.
El contador de iteración actual del bucle. Ver el método Ev::iteration().
El número de watchers pendientes.
0
indica que no hay watchers pendientes.
Un valor alto para io_interval permite a
libev pasar más tiempo recolectando
los eventos EvIo, así, más eventos
pueden ser gestionados por iteración, pero esto aumentará la
latencia. Los tiempos de espera máximos (tanto para
EvPeriodic como para EvTimer)
no se verán afectados. Establecer esta opción a un valor
distinto de cero introducirá una llamada adicional a sleep()
en la mayoría de las iteraciones del bucle.
El tiempo de pausa asegura que libev
no consultará EvIo más de una vez
durante este intervalo, en promedio. La mayoría de los programas
pueden beneficiarse estableciendo
io_interval a un valor cercano a
0.1
, lo cual es generalmente suficiente para los
servidores interactivos (y no destinados a juegos). Generalmente
no tiene sentido establecer este valor a menos de
0.01
, ya que se acerca a la
granularidad a nivel de tiempos de la mayoría de los sistemas.
Ver también las » funciones que controlan los bucles de eventos.
Un valor alto para timeout_interval permite a libev pasar más tiempo recolectando los tiempos de espera máximos, pero como consecuencia aumenta la latencia, el estrés y la inexactitud (la función de retrollamada del watcher será llamada más tarde). Los watchers EvIo no se verán afectados. Establecer este valor a un valor no nulo no introducirá ninguna sobrecarga adicional a libev. Ver también las » funciones que controlan los bucles de eventos.
La profundidad de la recursión. Ver el método Ev::depth().