Compréhension des threads et des coroutines en PHP
1. Les threads sont également appelés processus légers, qui est une unité d'exécution de base du processeur et la plus petite unité d'exécution de programme, comprend l'ID de thread, le compteur de programme, l'ensemble de registres et la pile. L'introduction de threads réduit la surcharge liée à l'exécution simultanée de programmes et améliore les performances de concurrence du système d'exploitation. Les threads ne disposent pas de leurs propres ressources système.
L'avantage des threads par rapport aux processus est qu'ils sont plus rapides. Qu'il s'agisse de créer un nouveau thread ou de terminer un thread ; qu'il s'agisse de basculer entre les threads, de partager des données ou de communiquer entre les threads, leur vitesse est plus rapide que cela. de processus. Gros avantage.
L'émergence des threads vise à réduire la consommation de changement de contexte, à améliorer la simultanéité du système et à surmonter le défaut selon lequel un processus ne peut faire qu'une seule chose, rendant ainsi possible la simultanéité intra-processus.
2. Coroutine
Coroutine est un fil de discussion en mode utilisateur Pour comprendre ce qu'est un « fil de discussion en mode utilisateur », vous devez d'abord comprendre ce que c'est. "thread d'état du noyau". Les threads d'état du noyau sont planifiés par le système d'exploitation. Lors du changement de contexte de thread, vous devez d'abord enregistrer le contexte du thread précédent, puis exécuter le thread suivant lorsque les conditions sont remplies, revenir au thread précédent et restaurer le contexte. Il en va de même pour les coroutines, sauf que les threads en mode utilisateur ne sont pas planifiés par le système d'exploitation, mais par les programmeurs, en mode utilisateur.
yield
Avant l'émergence des coroutines, la concurrence multitâche doit être réalisée À l'ère du non-OS (système d'exploitation), l'idée de . Les machines à états peuvent être utilisées pour implémenter le multitâche. Désassemblez et exécutez plusieurs tâches dans un environnement à processus unique, mais ce mode nécessite que les développeurs aient une compréhension claire de chaque tâche, et les développeurs doivent également développer des fonctions liées aux tâches (telles que comme la communication entre les tâches) par eux-mêmes. Plus tard, OS (système d'exploitation) est apparu et nous avons commencé à utiliser les fonctions de processus et de thread fournies par OS pour réaliser facilement le multitâche. Dans le système d'exploitation, le changement de contexte de processus est contrôlé par le noyau du système d'exploitation. Mais ensuite, un problème est apparu. Les changements fréquents de contexte de processus ont entraîné une diminution des performances du système d'exploitation (principalement l'exécution à court terme de processus de tâches à faible consommation).
Afin de résoudre ce problème, un nouveau concept a commencé à être proposé, qui consiste à exécuter plusieurs tâches dans le même processus ou thread. Ce problème équivaut à revenir aux premières implémentations multitâches dans le système d'exploitation. -ère libre. Et maintenant, la solution s’appelle les coroutines. Son essence est de transférer une partie de la tâche en passant du noyau à la couche application.
Pour implémenter les coroutines, php propose deux nouvelles choses : des générateurs et des mots-clés de rendement.
(1)Qu'est-ce qu'un générateur ?Le générateur hérite et implémente l'itérateur, qui est similaire à la définition de fonction dans le code PHP, mais utilise le mot-clé rendement en interne, tel que :
Lorsqu'il est utilisé, il ressemble à ceci :
D'accord, qu'est-ce que cela signifie de l'utiliser comme ça ?
(1) D'abord $my_gen = gen(); ce code instancie simplement un nouveau générateur, le code à l'intérieur n'est pas exécuté (2) $my_gen->current(); gen1" à l'étape 2 du générateur. À ce moment, le code est interrompu et la chaîne "gen1" est passée au générateur $my_gen et est utilisée comme valeur de retour de la fonction current() ;
If vous continuez à utiliser la méthode current() pour appeler ici, le résultat ne changera pas. La valeur de retour de $my_gen est toujours gen1
(3) Après l'exécution de send("main send"), la chaîne "main send" " est Le générateur $my_gen est transmis et le générateur est transmis à ret comme valeur de retour de rendement à l'étape 2 ; via la méthode send(), le contexte précédent sera trouvé et continuera vers le bas.
(4) Une fois l'étape 3 du générateur exécutée, lorsque l'étape 4 est rencontrée, il entrera à nouveau dans l'interruption lorsque le rendement sera rencontré.
Le contenu ci-dessus est à titre de référence uniquement !
Tutoriel recommandé :
Tutoriel vidéo PHPCe 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!