Index du contenu
En este diagrama, el Productor se está ejecutando en su propio Hilo (aunque podría también se ejecuta en un proceso separado) y coloca datos en algunos datos compartidos comunes envase. Posteriormente, varios Consumidores independientes pueden consumir ese datos cuando están disponibles y cuando son libres de procesar los datos. Sin embargo, hay No tiene sentido que los consumidores revisen repetidamente el contenedor en busca de datos como ese sería una pérdida de recursos (por ejemplo, en términos de ejecución de código en un procesador y de cambio de contexto entre múltiples subprocesos o procesos). Por lo tanto, necesitamos alguna forma de notificación o sincronización entre el Productor y el Consumidor para manejar esta situación. Python proporciona varias clases en el subproceso (y también en el multi- procesamiento) biblioteca que se puede utilizar para administrar bloques de código críticos. Estos las clases incluyen Bloqueo, Condición y Semáforo. 32.5 Bloqueos de pitón La clase Lock definida (tanto en el threading como en el multiprocesamiento) bibliotecas) proporciona un mecanismo para sincronizar el acceso a un bloque de código. El El objeto de bloqueo puede estar en uno de dos estados bloqueado y desbloqueado (con el estado inicial siendo desbloqueado). El bloqueo otorga acceso a un solo hilo a la vez; otros hilos debe esperar a que el Bloqueo se libere antes de avanzar. La clase Lock proporciona dos métodos básicos para adquirir el bloqueo (acquire()) y liberando (liberar()) la cerradura. • Cuando el estado del objeto Bloquear está desbloqueado, adquirir() cambia el estado a bloqueado y regresa inmediatamente. • Cuando el estado está bloqueado, la adquisición() se bloquea hasta que una llamada a la liberación() en otro hilo lo cambia a desbloqueado, luego la llamada de adquisición () lo restablece a bloqueado y vuelve. • El método release() solo debe llamarse en estado bloqueado; cambia el estado para desbloquear y vuelve inmediatamente. Si se intenta liberar un bloqueo desbloqueado, se generará un RuntimeError. A continuación se muestra un ejemplo del uso de un objeto de bloqueo: 32.4 Sincronización de código concurrente 383
popular post
Temas de Pregrado en Ciencias de la Computación Guía avanzada a Python 3 Programación Juan caza
Lire plusTemas de Pregrado en Ciencias de la Computación Guía avanzada a Python 3 Programación Juan caza
Lire plus• https://docs.python.org/3/ El sitio principal de documentación de Python 3. Contiene tutoriales, referencias de bibliotecas, guías de configuración e instalación, así como Python cómo-tos • https://docs.
Lire plus