Le module
Python de Python offre deux outils de synchronisation cruciaux: threading
et Lock
, tous deux conçus pour contrôler l'accès aux ressources partagées dans des applications multithread. Cependant, leurs fonctionnalités diffèrent considérablement. RLock
Lock
Lock
<code class="language-python">import threading lock = threading.Lock() def critical_section(): lock.acquire() try: print(f"{threading.current_thread().name} is accessing the shared resource.") finally: lock.release() thread1 = threading.Thread(target=critical_section) thread2 = threading.Thread(target=critical_section) thread1.start() thread2.start() thread1.join() thread2.join()</code>
RLock
RLock
<code class="language-python">import threading rlock = threading.RLock() def recursive_task(count): rlock.acquire() try: print(f"{threading.current_thread().name} acquired the lock; count = {count}") if count > 0: recursive_task(count - 1) # Recursive call; re-acquires the lock finally: rlock.release() thread = threading.Thread(target=recursive_task, args=(3,)) thread.start() thread.join()</code>
Lock
RLock
Feature |
Lock (threading.Lock) |
RLock (threading.RLock) |
---|---|---|
Reentrancy | Non-reentrant | Reentrant |
Use Case | Simple locking | Recursive/nested locking |
Performance | Generally faster | Slightly more overhead |
Lock
et RLock
Lock
pour les scénarios de verrouillage simples où la réentrance n'est pas nécessaire. C'est plus simple et souvent plus rapide. RLock
lors de la gestion des fonctions récursives ou du verrouillage imbriqué, empêchant les blocs de bloces potentiels. La complexité supplémentaire est justifiée par la prévention des impasses dans ces situations spécifiques. 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!