Threading.Timer - Maintenir le contrôle sur les fonctions répétitives
Threading.Timer de Python fournit un mécanisme pour planifier l'exécution des fonctions à des intervalles de temps spécifiés. Cependant, l'approche initiale utilisant plusieurs appels à start() peut entraîner des erreurs d'exécution.
Pour résoudre ce problème, il est recommandé de créer une classe de thread personnalisée, comme démontré dans la solution ci-dessous :
import threading class MyThread(threading.Thread): def __init__(self, event, function): threading.Thread.__init__(self) self.stopped = event self.function = function def run(self): while not self.stopped.wait(0.5): self.function()
Dans cette classe, l'événement arrêté est utilisé pour contrôler l'exécution du thread. Au lieu de démarrer et d'arrêter le minuteur plusieurs fois, le thread s'exécute en continu, vérifiant l'événement arrêté à intervalles réguliers. Lorsque l'événement est défini, le thread se termine.
Dans le code qui a lancé le minuteur, vous pouvez ensuite utiliser l'événement arrêté pour arrêter le minuteur :
stopFlag = threading.Event() thread = MyThread(stopFlag, function) thread.start() # To stop the timer later on stopFlag.set()
Cette approche fournit une approche propre et efficace pour démarrer, arrêter et réinitialiser la minuterie, permettant un contrôle flexible sur les exécutions de fonctions récurrentes.
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!