NOVINKA! E-learningové kurzy umělé inteligence. Nyní AI za nejlepší ceny. Zjisti více:
NOVINKA – Víkendový online kurz Software tester, který tě posune dál. Zjisti, jak na to!

Lekce 16 - Bariéry a závory v C++

V minulé lekci, POSIX a Windows Threading library v C++, jsme si představili nativní knihovny POSIX threads sloužící pro UNIX-like systémy a Windows Threading pro Windows.

Dnes si opět rozšíříme obzory a podíváme se na bariéry a závory, které nám umožňují paralelizovat naše algoritmy.

Bariéry

Bariéra (anglicky barrier) je struktura umožňující synchronizovat běh vláken.

Motivace

Na začátku kurzu jsme několikrát zdůrazňovali, že je potřeba nad programem myslet paralelně, nikoli sekvenčně. Operační systém se může rozhodnout nějaké vlákno pozastavit, spustit se zpožděním a podobně. Ve výsledku se může stát, že vlákno začínající voláním sleep() po 1s může být spuštěno dříve, než vlákno bez uspání. Právě bariéry tento problém řeší.

Funkčnost

Při vytvoření bariéry předáme počet vláken, které mají na bariéře čekat. Každé vlákno, které se k bariéře dostane, se zablokuje. Teprve až je počet čekajících vláken roven předané hodnotě, bariéra vlákna odblokuje a dovolí jim pokračovat (někdy se můžeme setkat s pojmem "protržení bariéry"). Poté se bariéra opět aktivuje a znovu čeká na daný počet vláken.

Svým způsobem tedy bariéra zajišťuje, že se všechna vlákna (resp. jejich daný počet) setkají na stejném místě v programu nebo minimálně na stejné synchronizační entitě.

Závora

Závora (anglicky latch) je zjednodušení bariéry.

Funkčnost

Fungování je totožné s bariérou, pouze s tím rozdílem, že závora


 

...konec náhledu článku...
Pokračuj dál

Znalosti v hodnotě stovek tisíc získáš za pár korun

Došel jsi až sem a to je super! Věříme, že ti první lekce ukázaly něco nového a užitečného.
Chceš v kurzu pokračovat? Přejdi do prémiové sekce.

Koupit tento kurz

Koupit všechny aktuálně dostupné lekce s funkcí odevzdávání úloh za pouhých 525 Kč
Aktuální stav konta 0 Kč
Koupí tohoto balíčku získáš přístup ke všem 23 článkům (23 lekcí) tohoto kurzu.

Obsah článku spadá pod licenci Premium, koupí článku souhlasíš se smluvními podmínkami.

Co od nás v dalších lekcích dostaneš?
  • Neomezený a trvalý přístup k jednotlivým lekcím.
  • Kvalitní znalosti v oblasti IT.
  • Dovednosti, které ti pomohou získat vysněnou a dobře placenou práci.

Popis článku

Požadovaný článek má následující obsah:

V C++ tutoriálu si představíme nové synchronizační entity - bariéry a závory, pomocí kterých můžeme vlákna zesynchronizovat na konkrétním místě.

Kredity získáš, když podpoříš naši síť. To můžeš udělat buď zasláním symbolické částky na podporu provozu nebo přidáním obsahu na síť.

Článek pro vás napsal Patrik Valkovič
Avatar
Věnuji se programování v C++ a C#. Kromě toho také programuji v PHP (Nette) a JavaScriptu (NodeJS).
Aktivity