Maison >développement back-end >Tutoriel Python >Comment utiliser le module multitraitement pour la gestion multi-processus dans Python 3.x
Comment utiliser le module multitraitement pour la gestion multi-processus dans Python 3.x
Introduction :
En Python, la popularité des processeurs multicœurs fait de la programmation multi-processus une compétence importante. Le module multiprocessing est une bibliothèque standard en Python permettant de gérer des multi-processus. Cet article présentera comment utiliser le module multitraitement pour la gestion multi-processus et l'illustrera avec des exemples de code.
1. Introduction au module multitraitement
Le module multitraitement de Python fournit un wrapper qui peut mapper les programmes Python pour qu'ils s'exécutent sur plusieurs processus. Le module multitraitement est thread-safe et offre plus de fonctionnalités que le module threading.
2. Fonctions et classes communes du module multitraitement
3. Exemple de code utilisant le module multitraitement
Ce qui suit est un exemple simple montrant comment utiliser le module multitraitement pour la gestion multi-processus :
import multiprocessing def worker(name): print('Worker %s' % name) return name if __name__ == '__main__': pool = multiprocessing.Pool(processes=4) results = [] for i in range(4): result = pool.apply_async(worker, args=(i,)) results.append(result) pool.close() pool.join() for result in results: print(result.get())
Dans le code ci-dessus, nous définissons d'abord une fonction de travail, qui accepte un nom. paramètres et imprimer le nom. Ensuite, utilisez multiprocessing.Pool dans le programme principal pour créer un pool de processus contenant 4 processus. Ensuite, nous utilisons la méthode apply_async pour exécuter de manière asynchrone la fonction de travail, en passant un paramètre i et en l'ajoutant à la liste des résultats. Enfin, attendez que tous les processus terminent leur exécution via les méthodes pool.close() et pool.join(). Enfin, nous obtenons le résultat de l'exécution via la méthode result.get() et l'imprimons.
L'exécution du code ci-dessus produira les résultats suivants :
Worker 0 Worker 1 Worker 2 Worker 3 0 1 2 3
Résumé :
En utilisant le module multitraitement, nous pouvons facilement effectuer une programmation multi-processus. Cet article présente les fonctions et classes communes du module multitraitement et montre comment les utiliser via un exemple de code. L'utilisation du module multitraitement permet de mieux utiliser les processeurs multicœurs et d'améliorer l'efficacité de l'exécution du programme.
Référence :
[1] Documentation officielle Python - module multitraitement https://docs.python.org/3/library/multiprocessing.html
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!