From 785f5f72b3b9713b34357e093313a5dbaec2ef77 Mon Sep 17 00:00:00 2001 From: Nolete19 Date: Fri, 24 Nov 2023 18:36:52 +0100 Subject: [PATCH] Ejercico de los cajeros con Lock de Manuel Portero --- ejerciciocajeroself.py | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 ejerciciocajeroself.py diff --git a/ejerciciocajeroself.py b/ejerciciocajeroself.py new file mode 100644 index 0000000..b3f6194 --- /dev/null +++ b/ejerciciocajeroself.py @@ -0,0 +1,37 @@ +import threading + +# Creamos la clase con dichos atributos propios de la clase +class CajeroAutomatico: + def __init__(self): + # Los inicializamos + self.saldo_total = 1000 + self.lock = threading.Lock() + +cajero = CajeroAutomatico() # Creamos un objeto de la clase + +def verificar_retirar_dinero(self,cantidad): + with self.lock: # Bloqueamos las variables para que todos los hilos no accedan a la vez + if self.saldo_total >= cantidad: + self.saldo_total = self.saldo_total - cantidad # Decrementamos la cantidad del cajero en el + return True + else: + return False # Devolvemos false si intenta retirar mas dinero del que hay en el cajero + +def usuario(cantidad_sacar): + if verificar_retirar_dinero(cajero,cantidad_sacar): + print(f"Retirada exitosa de {cantidad_sacar} euros.") + else: + print("Saldo insuficiente.") + + +hilos = [] # Creamos una lista con los hilos + +for x in range(10): + t = threading.Thread(target=usuario, args=(200,)) + hilos.append(t) # Agregamos los hilos a la lista + t.start() # Ejecutamos los hilos + +for hilo in hilos: + t.join() # Hasta que no acaben antes que el hilo principal + +print(f"Saldo final: {cajero.saldo_total} euros.") # Mostramos el saldo final que queda en el cajero