POSLEDNÍ ŠANCE: Halloweenská akce brzy končí. Získej 66 % extra kreditů zdarma při nákupu od 1199 kreditů s promo kódem NEBOJSEIT66. Zjisti více:
NOVINKA: Začni v IT jako webmaster s komplexním akreditovaným online kurzem Tvůrce WWW stránek. Zjisti více:

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.

Omezená nabídka: Nauč se vše a ušetři

Koupit všechny aktuálně dostupné lekce s funkcí odevzdávání úloh za exkluzivní cenu 315 Kč
Aktuální stav konta 0 Kč
Koupí tohoto výhodného balíčku získáš přístup ke všem 23 článkům (23 lekcí) tohoto kurzu s kontrolou a certifikací a ještě navíc ušetříš 211 Kč. Nabídka je časově omezená a platí pro všechny lekce v kurzu. Nakup teď a získej limitovanou 40% slevu.

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