Politiques¶
Une politique de boucle d'événements est un objet global utilisé pour obtenir et définir la boucle d'événements actuelle, ainsi que créer de nouvelles boucles d'événements. La politique par défaut peut être remplacée par des alternatives intégrées afin d'utiliser d'autres implémentations de boucles d'événements, ou remplacée par une politique personnalisée qui peut remplacer ces comportements.
Un objet politique définit la notion de contexte et gère une boucle d'événement distincte par contexte. Ceci est valable fil par fil d'exécution par défaut, bien que les politiques personnalisées puissent définir le contexte différemment.
En utilisant une politique de boucle d'événement personnalisée, le comportement des fonctions get_event_loop()
, set_event_loop()
et new_event_loop()
peut être personnalisé.
Les objets politiques doivent implémenter les API définies dans la classe mère abstraite AbstractEventLoopPolicy
.
Obtenir et définir la politique¶
Les fonctions suivantes peuvent être utilisées pour obtenir et définir la politique du processus en cours :
- asyncio.get_event_loop_policy()¶
Renvoie la politique actuelle à l'échelle du processus.
- asyncio.set_event_loop_policy(policy)¶
Définit la politique actuelle sur l'ensemble du processus sur policy.
Si policy est définie sur
None
, la politique par défaut est restaurée.
Objets politiques¶
La classe mère abstraite de la politique de boucle d'événements est définie comme suit :
- class asyncio.AbstractEventLoopPolicy¶
Une classe de base abstraite pour les politiques asyncio.
- get_event_loop()¶
Récupère la boucle d'évènements pour le contexte actuel.
Renvoie un objet de boucle d'événements en implémentant l'interface
AbstractEventLoop
.Cette méthode ne devrait jamais renvoyer
None
.Modifié dans la version 3.6.
- set_event_loop(loop)¶
Définit la boucle d'événements du contexte actuel sur loop.
- new_event_loop()¶
Crée et renvoie un nouvel objet de boucle d'événements.
Cette méthode ne devrait jamais renvoyer
None
.
asyncio est livré avec les politiques intégrées suivantes :
- class asyncio.DefaultEventLoopPolicy¶
La politique asyncio par défaut. Utilise
SelectorEventLoop
sur les plates-formes Unix etProactorEventLoop
sur Windows.Il n'est pas nécessaire d'installer la politique par défaut manuellement. asyncio est configuré pour utiliser automatiquement la politique par défaut.
Modifié dans la version 3.8: Sous Windows,
ProactorEventLoop
est désormais utilisée par défaut.Obsolète depuis la version 3.12: The
get_event_loop()
method of the default asyncio policy now emits aDeprecationWarning
if there is no current event loop set and it decides to create one. In some future Python release this will become an error.
- class asyncio.WindowsSelectorEventLoopPolicy¶
Politique de boucle d'événements alternative utilisant l'implémentation de la boucle d'événements
ProactorEventLoop
.Disponibilité : Windows.
- class asyncio.WindowsProactorEventLoopPolicy¶
Politique de boucle d'événements alternative utilisant l'implémentation de la boucle d'événements
ProactorEventLoop
.Disponibilité : Windows.
Politiques personnalisées¶
Pour implémenter une nouvelle politique de boucle d’événements, il est recommandé de sous-classer DefaultEventLoopPolicy
et de réimplémenter les méthodes pour lesquelles un comportement personnalisé est souhaité, par exemple :
class MyEventLoopPolicy(asyncio.DefaultEventLoopPolicy):
def get_event_loop(self):
"""Get the event loop.
This may be None or an instance of EventLoop.
"""
loop = super().get_event_loop()
# Do something with loop ...
return loop
asyncio.set_event_loop_policy(MyEventLoopPolicy())