Maison >développement back-end >tutoriel php >Comment est défini l'ordre d'exécution des écouteurs d'événements PHP ?

Comment est défini l'ordre d'exécution des écouteurs d'événements PHP ?

WBOY
WBOYoriginal
2024-04-17 15:21:01443parcourir

L'ordre d'exécution des écouteurs d'événements PHP est déterminé à la fois par la priorité et l'ordre d'enregistrement : Priorité : des valeurs plus élevées indiquent une exécution avec une priorité plus élevée (plage de -10 à 10). Ordre d'enregistrement : les auditeurs ayant la même priorité sont exécutés dans l'ordre d'enregistrement.

PHP 事件监听器的执行顺序是如何定义的?

Séquence d'exécution des écouteurs d'événements PHP : une explication simple

Comprendre le système d'événements PHP

Le système d'événements en PHP utilise des écouteurs d'événements pour gérer les événements. Les écouteurs sont enregistrés en s'abonnant à des types d'événements spécifiques. Lorsque l'événement est déclenché, le système exécutera l'écouteur enregistré.

Ordre d'exécution

L'ordre d'exécution des écouteurs d'événements est déterminé par deux facteurs :

  • Priorité : Chaque écouteur se voit attribuer une valeur de priorité, une priorité plus élevée signifie une priorité d'exécution plus élevée.
  • Ordre d'inscription : Si plusieurs auditeurs ont la même priorité, ils sont exécutés dans l'ordre d'inscription.

Priority

La priorité de l'auditeur est définie via la méthode withPriority() La plage de valeurs de priorité est de -10 à 10, où : withPriority() 方法设置,优先级值范围为 -10 到 10,其中:

  • -10:最低优先级
  • 10:最高优先级

默认情况下,监听器的优先级为 0。

注册顺序

监听器通过 addListener()subscribe() 方法添加到事件调度器。注册顺序由这些方法的调用顺序决定。

实战案例

以下代码片段演示了监听器执行顺序的实战案例:

use Symfony\Component\EventDispatcher\EventDispatcher;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\EventDispatcher\Event;

class EventA extends Event {}
class EventB extends Event {}

class ListenerA implements EventSubscriberInterface
{
    public static function getSubscribedEvents(): array
    {
        return [
            'event_a' => ['onEventA', -5],
            'event_b' => ['onEventB', 1],
        ];
    }

    public function onEventA(EventA $event)
    {
        echo "Listener A: Event A\n";
    }

    public function onEventB(EventB $event)
    {
        echo "Listener A: Event B\n";
    }
}

class ListenerB implements EventSubscriberInterface
{
    public static function getSubscribedEvents(): array
    {
        return [
            'event_a' => ['onEventA', 5],
            'event_b' => ['onEventB', -2],
        ];
    }

    public function onEventA(EventA $event)
    {
        echo "Listener B: Event A\n";
    }

    public function onEventB(EventB $event)
    {
        echo "Listener B: Event B\n";
    }
}

$dispatcher = new EventDispatcher();
$dispatcher->addSubscriber(new ListenerA());
$dispatcher->addSubscriber(new ListenerB());

$dispatcher->dispatch(new EventA());
$dispatcher->dispatch(new EventB());

输出:

Listener A: Event A
Listener B: Event A
Listener A: Event B
Listener B: Event B

在这个例子中,ListenerBEventA 具有更高的优先级,因此它比 ListenerA 先被执行。对于 EventBListenerA

🎜-10 : la priorité la plus basse. 🎜 🎜10 : Priorité la plus élevée 🎜🎜🎜Par défaut, la priorité de l'auditeur est 0. 🎜🎜🎜Ordre d'inscription🎜🎜🎜Les auditeurs sont ajoutés au répartiteur d'événements via la méthode addListener() ou subscribe(). L'ordre d'enregistrement est déterminé par l'ordre dans lequel ces méthodes sont appelées. 🎜🎜🎜Cas pratique🎜🎜🎜L'extrait de code suivant illustre un cas pratique de la séquence d'exécution de l'écouteur : 🎜rrreee🎜🎜Sortie : 🎜🎜rrreee🎜Dans cet exemple, ListenerB répond à EventA a une priorité plus élevée, il est donc exécuté avant ListenerA. Pour EventB, ListenerA a une priorité plus élevée, il est donc exécuté en premier. 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn