EvEmbed::__construct

(PECL ev >= 0.2.0)

EvEmbed::__constructConstruit un objet EvEmbed

Description

publicEvEmbed::__construct(
    object$other,
    callable$callback = ?,
    mixed$data = ?,
    int$priority = ?
)

Il s'agit d'un type de watcher avancé qui permet d'intégrer une boucle d'événement dans une autre (actuellement, seuls les événements IO sont supportés dans la boucle interne, les autres types de watcher ne doit pas être utilisés).

Voir la »  documentation libev pour plus de détails.

Ce watcher est le plus utile sous les systèmes BSDkqueue n'est pas utilisé, pour être capable de gérer un grand nombre de sockers. Voir l'exemple ci-dessous.

Liste de paramètres

other

Une instance de EvLoop. La boucle à intégrer ; elle doit être encapsulable (voir la méthode Ev::embeddableBackends()).

callback

Voir les fonctions de rappel des Watcher.

data

Données personnalisées à associer avec le watcher.

priority

Priorité du Watcher

Exemples

Exemple #1 Encapsulage d'une boucle créée avec le gestionnaire kqueue dans la boucle par défaut

<?php

$loop = EvLoop::defaultLoop();
$socket_loop = NULL;
$embed = NULL;

if (
Ev::supportedBackends() & ~Ev::recommendedBackends() & Ev::BACKEND_KQUEUE) {
if ((
$socket_loop = new EvLoop(Ev::BACKEND_KQUEUE))) {
$embed = new EvEmbed($loop);
}
}

if (!
$socket_loop) {
$socket_loop = $loop;
}

// Maintenant, on utilise $socket_loop pour tous les sockets, et $loop poour tout le reste
?>

Voir aussi

To Top