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

A seguir: Liberação do Processador Acima: Exclusão Mútua Anterior: Deadlocks


Buffer com sincronização interna: programação com espera ocupada


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



Osvaldo Carvalho