UFMG - Pós-graduação em Ciência da Computação - Programação Paralela

A seguir: Deadlocks Acima: Exclusão Mútua Anterior: Buffer com sincronização interna:


Buffer com sincronização interna: programação sujeita a bloqueios


char B[10];
int p = 0, c = 0, n = 0;
key mutex ;
 
void Put(char x) {
		 lock(mutex);
		 		 while (n $\geq$ 10); 
		 		 /* espera por uma posicao vazia */
		 		 B[p] = x; p = (p+1) % 10; n++;
		 unlock(mutex); 
}
 
void Get(char *x) {
		 lock(mutex);
		 		 while (n $\leq$ 0) ; 
		 		 /* espera por uma posicao cheia */
		 		 *x = B[c]; c = (c+1) % 10; n-;
		 unlock(mutex); 
}



Osvaldo Carvalho