Le Global Interpreter Lock est un verrou qui protège l'accès aux objets Python et contrôle soigneusement l'exécution des threads, empêchant la concurrence concurrente dans l'accès et la modification des données, garantissant qu'un seul thread peut exécuter du code Python à la fois. .
Sans le GIL, la gestion de la mémoire de Python ne peut pas être thread-safe, cela pourrait entraîner des incohérences et des plantages. (impasses)
C'est très simple, Thread détiendra le GIL lorsqu'il sera en cours d'exécution, et après son exécution, Thread libérera le GIL. Les threads suivants doivent demander l'accès au GIL afin d'exécuter des Opcodes (opérations de bas niveau). Je dessine ci-dessous un exemple de comportement de GIL :
Cela signifie que les développeurs Python peuvent utiliser du code asynchrone et du code multithread et ne jamais avoir à se soucier d'acquérir des verrous sur des variables dans le processus en cours d'exécution ou de voir les processus planter à cause de blocages.
Au lieu d'utiliser des threads, vous pouvez utiliser des processus pour exécuter vos algorithmes dans certains cas. Pour les opérations IO/Bound, le threading et la concurrence peuvent vous permettre de mieux utiliser vos ressources, pour les opérations CPU/Bound, vous pouvez utiliser la bibliothèque multitraitement pour une meilleure utilisation des ressources.
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!