Maison  >  Article  >  développement back-end  >  Explication détaillée des exemples multi-threading php

Explication détaillée des exemples multi-threading php

小云云
小云云original
2018-03-12 15:09:192132parcourir

La plus petite unité que le système d'exploitation peut effectuer la planification des opérations est incluse dans le processus et constitue l'unité d'exploitation réelle du processus. Un thread fait référence à une séquence unique de flux de contrôle dans un processus. Plusieurs threads peuvent s'exécuter simultanément dans un processus et chaque thread exécute plusieurs tâches en parallèle.

Un programme multithread est plus susceptible d'être appelé par un programme qu'un programme monothread, donc les programmes multithread sont généralement plus efficaces que les programmes monothread.
Plusieurs threads d'un programme multithread peuvent s'exécuter sur plusieurs cœurs d'un processeur multicœur, tirant pleinement parti du processeur multicœur.
Caractéristiques :
La surcharge du système liée à la création et au changement de threads est inférieure à celle des processus, elle sera donc plus efficace que plusieurs processus dans une certaine mesure.
Les threads partagent naturellement l'espace mémoire et la communication entre les threads est plus simple, évitant ainsi l'introduction d'une nouvelle complexité par le processus IPC.
Scénarios applicables :
L'utilisation aléatoire du multi-threading ne peut pas améliorer l'efficacité d'exécution du programme. La création et la destruction de threads, le changement de contexte et la synchronisation des threads ont tous des coûts de performances.
1. Le blocage des E/S entraînera la planification des tâches dans le système d'exploitation et bloquera la tâche en cours. Par conséquent, lorsqu'il y a beaucoup d'E/S dans le code, le code peut être parallélisé lors de l'utilisation de plusieurs threads. Par exemple, lire un fichier entier plusieurs fois ou demander plusieurs ressources réseau.
2. Le multi-threading peut utiliser pleinement le CPU, donc lorsqu'il y a plusieurs codes de calcul volumineux, vous pouvez également utiliser le multi-threading pour les exécuter en parallèle
Multi-threading PHP :
PHP. ne prend pas en charge le multi-threading par défaut. Vous devez ajouter l'extension pthread
Vous devez utiliser le paramètre --enable-maintainer-zts pour recompiler PHP. Ce paramètre spécifie la méthode de sécurité des threads lors de la compilation de PHP.
Sécurité des threads :
La sécurité des threads est un terme en programmation, ce qui signifie que lorsqu'une fonction ou une bibliothèque de fonctions est appelée dans un environnement multithread, elle peut gérer correctement les variables partagées entre plusieurs threads, afin que le programme fonctionne Terminez correctement.
En multi-threading traditionnel, puisque plusieurs threads partagent des variables, les problèmes suivants peuvent survenir :
Il existe un tableau global $arr = array('a');;
Le thread A obtient la longueur du array est 1;
Thread B obtient que la longueur du tableau soit 1;
Thread A fait apparaître l'élément du tableau $a = array_pop($arr);;
Thread B également fait apparaître l'élément du tableau$ b = array_pop($arr); $a = null;;
À ce moment-là, un événement surnaturel s'est produit dans le thread B. La longueur du tableau était évidemment supérieure à 0, ou il n'y a pas eu de pop. ;
Implémentation PHP :
Utilisation Le mécanisme TSRM isole les variables globales et les variables statiques
Copiez les variables globales et les variables statiques dans chaque thread. Chaque thread utilise une sauvegarde du thread principal, évitant ainsi les conflits de variables et l'absence de threads. Question de sécurité.
Problèmes qui surviennent :
Une fois le sous-thread exécuté, le thread principal ne peut plus effectuer d'ajustements détaillés sur le sous-thread. Les threads perdent la capacité de transmettre des messages entre les threads via des variables globales.
L'utilisation du mécanisme TSRM pour allouer et utiliser des variables entraînera des pertes supplémentaires, utilisez donc ZTS (non-thread-safe) dans un environnement PHP qui ne nécessite pas de multi-threading
Classes et méthodes :
PHP. encapsule les threads dans Threads Les classes et les threads sont créés en instanciant un objet thread. En raison de l'encapsulation de la classe, l'utilisation intelligente des variables
est transmise via le constructeur et les résultats de l'opération du thread doivent également être transmis. via des variables de classe.
Méthode Thread :
run() : Cette méthode est une méthode abstraite. Chaque thread doit implémenter cette méthode. Une fois le thread démarré, le code de cette méthode sera automatiquement exécuté
start() : Appelez cette méthode dans le thread principal pour démarrer l'exécution d'un thread ;
join() : Chaque thread est exécuté de manière asynchrone par rapport au thread principal. L'appel de cette méthode attendra la fin du thread
kill() : Force. le thread à terminer ;
isRunning() : Renvoie l'état d'exécution du thread. Il retournera true lorsque le thread exécute le code de la méthode run()
En raison de l'implémentation de la sécurité des threads ; Les multi-threads PHP commencent à s'exécuter, ils ne peuvent plus transmettre la communication spatiale de la mémoire partagée, les threads ne peuvent pas être réutilisés via la communication inter-thread.
Recommandations associées :

Application de la communication par pipeline multithread PHP

Comment implémenter Web Worker avec le multi-threading H5

Comment implémenter des appels multi-thread asynchrones en PHP

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