From: tailor Date: Mon, 28 Nov 2005 00:46:37 +0000 (+0000) Subject: todavia no anda muy bien, pero ya lo voy a sacar andando.. X-Git-Tag: darcs_import~16 X-Git-Url: https://git.llucax.com/z.facultad/75.59/filosofos.git/commitdiff_plain/1e5706e940d3ead1978c60c803378bf73dd94f74 todavia no anda muy bien, pero ya lo voy a sacar andando.. con semaforos. --- diff --git a/src/filosofos2.py b/src/filosofos2.py index c86036c..da6fa8b 100644 --- a/src/filosofos2.py +++ b/src/filosofos2.py @@ -9,52 +9,58 @@ from sync import * palitos = [] semaforos = [] - class filosofo(threading.Thread): - def __init__(self, numeracion, cant): + def __init__(self, izq, der, cant): threading.Thread.__init__(self) - self.id = numeracion + self.id = izq self.rnd = random.Random() self.cant = cant # cantidad de veces que va a comer self.comi = 0 # cantidad de veces que comio - self.derecho = False - self.izquierdo = False + self.der = der + self.izq = izq + self.ambos = [False, False] self.start() def agarrarPalitoDerecho(self): - if self.id+1 == len(palitos): ind = 0 - else: ind = self.id+1 - semaforos[ind].acquire() - self.derecho = palitos[ind] - if self.derecho: - print 'Soy '+str(self.id)+' y agarre el palito derecho' - else: self.derecho = False + semaforos[self.der].acquire() + palitos[self.der] = False + self.ambos[1] = True + print 'Soy '+str(self.id)+' y agarre el palito derecho' def agarrarPalitoIzquierdo(self): - semaforos[self.id].acquire() - self.izquierdo = palitos[self.id] - if self.izquierdo: - print 'Soy '+str(self.id)+' y agarre el palito izquierdo' - else: self.izquierdo = False + semaforos[self.izq].acquire() + palitos[self.izq] = False + self.ambos[0] = True + print 'Soy '+str(self.id)+' y agarre el palito izquierdo' + + def dejarPalitoDerecho(self): + palitos[self.der] = True + semaforos[self.der].release() + self.ambos[1] = False + print 'Soy '+str(self.id)+' y solte el palito derecho' + + def dejarPalitoIzquierdo(self): + palitos[self.izq] = True + semaforos[self.izq].release() + self.ambos[0] = False + print 'Soy '+str(self.id)+' y solte el palito izquierdo' def pensar(self): - t = self.rnd.randint(1,5) + t = self.rnd.randint(2,5) print 'Soy '+str(self.id)+' y voy a pensar durante '+str(t)+' segundos' time.sleep(t) def comer(self): t = self.rnd.randint(1,5) - if self.derecho and self.izquierdo: + if self.ambos == [True, True]: print 'Soy '+str(self.id)+' y voy a comer '+str(t)+' segundos' self.comi = self.comi + 1 self.izquierdo = self.derecho = False time.sleep(t) - if self.id+1 == len(palitos): ind = 0 - else: ind = self.id+1 - palitos[self.id] = True - palitos[ind] = True - semaforos[self.id].release() - semaforos[ind].release() + + self.dejarPalitoIzquierdo() + self.dejarPalitoDerecho() + print 'Soy '+str(self.id)+' y solte los palitos' return True else: return False @@ -64,7 +70,6 @@ class filosofo(threading.Thread): else: return False def run(self): - time.sleep(self.rnd.randint(1,5)) while not self.lleno(): self.agarrarPalitoDerecho() self.agarrarPalitoIzquierdo() @@ -75,10 +80,13 @@ if __name__ == '__main__': if len(sys.argv) < 3: print "Modo de uso: "+ str(sys.argv[0]) + " " sys.exit() + if int(sys.argv[1]) <= 1: + print "Debe haber por lo menos 2 chinos" + sys.exit() chinos = [] - for i in range(int(sys.argv[1])): + todos = int(sys.argv[1]); + for i in range(todos): palitos.append(True) semaforos.append(threading.Semaphore(1)) - chinos.append(filosofo(i,int(sys.argv[2]))) - + chinos.append(filosofo(i,(i+1)%todos,int(sys.argv[2])))