Web - Amazon

We provide Linux to the World


We support WINRAR [What is this] - [Download .exe file(s) for Windows]

CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
SITEMAP
Audiobooks by Valerio Di Stefano: Single Download - Complete Download [TAR] [WIM] [ZIP] [RAR] - Alphabetical Download  [TAR] [WIM] [ZIP] [RAR] - Download Instructions

Make a donation: IBAN: IT36M0708677020000000008016 - BIC/SWIFT:  ICRAITRRU60 - VALERIO DI STEFANO or
Privacy Policy Cookie Policy Terms and Conditions
Algorytm piekarniany - Wikipedia, wolna encyklopedia

Algorytm piekarniany

Z Wikipedii

Algorytm piekarniany rozwiązujący wykluczanie się w sekcji krytycznej dla dowolnej N liczby procesów. Algorytm działa na podobnej zasadzie jak automaty do wydawania numerków w bankach i urzędach. Proces o najwyższym indeksie wykona swoją sekcję krytyczną najpóźniej.

Algorytm operuje na dwóch tablicach n-elementowych

int numerek[N];
 bool pobiera_numerek[N];

Implementacja algorytmu

void task_i(int i)
{
  const int id = i;
  while(1)
  {
   // sekcja lokalna
   pobiera_numerek[id] = true;
   numerek[i] = max(numerek) + 1;
   pobiera_numerek[id] = false; 
   for(k = 0; (k < N) && (k != id); k++)
   {
    if(numerek[k] == 0 ||
     numerek[id] == numerek[k] ||
     numerek[id] == numerek[k] && id < k)
       break;
   }
   // sekcja krytyczna
   numerek[id] = 0;
  }
 }

Wywołanie algorytmu (sygnalizacja wejścia do sekcji krytycznej) powoduje zaznaczenie faktu pobierania numeru w tablicy pobiera_numerek, wybranie numeru z tabeli numerek a następnie odznaczenie akcji w tablicy pobiera_numerek. Zwolnienie numeru realizowane jest przez wyzerowanie odpowiedniej wartości w tablicy numerek. W algorytmie przyjmuje się, że komputer może zapisać dowolną liczbę naturalną.

Istnieje jednak zasadnicza różnica między systemem przydzielania numerów porządkowych w urzędach a tym algorytmem. W algorytmie tym istnieje szansa, że dwa procesy otrzymają ten sam numerek. Gwarantowane jest jednak niejednoczesne udostępnienie im zasobu, gdyż kolejność wejścia do sekcji krytycznej regulowana jest także przez numer procesu. Można powiedzieć, że procesy wchodzą do seksji krytycznej w porządku leksykograficznym par (numerek, i).

Wadą tego algorytmu jest aktywne czekanie (proces oczekuje na udostępnienie zasobu wykonując pętlę sprawdzającą jego dostępność).

Our "Network":

Project Gutenberg
https://gutenberg.classicistranieri.com

Encyclopaedia Britannica 1911
https://encyclopaediabritannica.classicistranieri.com

Librivox Audiobooks
https://librivox.classicistranieri.com

Linux Distributions
https://old.classicistranieri.com

Magnatune (MP3 Music)
https://magnatune.classicistranieri.com

Static Wikipedia (June 2008)
https://wikipedia.classicistranieri.com

Static Wikipedia (March 2008)
https://wikipedia2007.classicistranieri.com/mar2008/

Static Wikipedia (2007)
https://wikipedia2007.classicistranieri.com

Static Wikipedia (2006)
https://wikipedia2006.classicistranieri.com

Liber Liber
https://liberliber.classicistranieri.com

ZIM Files for Kiwix
https://zim.classicistranieri.com


Other Websites:

Bach - Goldberg Variations
https://www.goldbergvariations.org

Lazarillo de Tormes
https://www.lazarillodetormes.org

Madame Bovary
https://www.madamebovary.org

Il Fu Mattia Pascal
https://www.mattiapascal.it

The Voice in the Desert
https://www.thevoiceinthedesert.org

Confessione d'un amore fascista
https://www.amorefascista.it

Malinverno
https://www.malinverno.org

Debito formativo
https://www.debitoformativo.it

Adina Spire
https://www.adinaspire.com