Vianoce v ITnetwork sú tu! Dobí si teraz kredity a získaj až 80 % extra kreditov na e-learningové kurzy ZADARMO. Zisti viac.
Hľadáme nové posily do ITnetwork tímu. Pozri sa na voľné pozície a pridaj sa k najagilnejšej firme na trhu - Viac informácií.

8. diel - Multithreading v Jave - Bariéra, CountDownLatch

V minulej lekcii, Multithreading v Jave - mutex , sme sa venovali Mutexům. Dnes si preberieme ďalšie veľmi dôležité synchronizačný primitívom v Jave - Bariéru. S bariérou si ukážeme ešte jedno podobné synchronizačný primitívom - CountDownLatch.

Bariéra

Bariéra slúži ako synchronizačný primitívom pre skupinu vlákien / procesov. Najčastejšie sa použije vo chvíli, keď vykonávame nejaký veľmi zložitý výpočet. Takýto výpočet môžeme rozložiť do viacerých vlákien. Každé vlákno potom bude počítať vlastný časť. Vo väčšine prípadov sú nasledujúce výpočty závislé na predchádzajúcich výsledkoch. To znamená, že keď rozložíme výpočet do viacerých samostatných vlákien, musíme počkať, kým nedopočítate všetky vlákna čiastkové výsledky. Keď posledná vlákno dokončí prácu, môže sa pokračovať v ďalšom výpočtu. A práve o počkanie na ostatné vlákna sa postará bariéra.

Na obrázku nižšie je pre ilustráciu vidieť, ako bariéra funguje. Sú tu štyri vlákna A, B, C, D. Vlákna A, C a D už dokončila svoju prácu a čakajú na vlákno B. Keď vlákno B dokončí svoju prácu, "prerazí" bariéru a práce môže pokračovať:

Príklad bariéry

Bariéra v Jave

V Jave je bariéra reprezentovaná triedou


 

...koniec náhľadu článku...
Pokračuj ďalej

Vedomosti v hodnote stoviek tisíc získaš za pár korún

Minul si až sem a to je super! Veríme, že ti prvé lekcie ukázali niečo nového a užitočného.
Chceš v kurze pokračovať? Prejdi do prémiové sekcie.

Obmedzená ponuka: Nauč sa všetko a ušetri

Kúpiť všetky aktuálne dostupné lekcie s funkciou odovzdávanie úloh a certifikátom za exkluzívnu cenu 150 kreditov
Aktuálny stav konta 0 kreditov
Kúpou tohoto výhodného balíčku získaš prístup ku všetkým 22 článkom (13 lekcií, 5 testov, 4 praktické cvičenia) s kontrolou a certifikáciou a ešte naviac ušetríš 601 Kč. Ponuka je časovo obmedzená a platí pro všetky lekcie v kurze. Nakúp teraz a získaj limitovanou 80% zľavu.

Obsah článku spadá pod licenciu Premium, kúpou článku súhlasíš so zmluvnými podmienkami.

Čo od nás v ďalších lekciách dostaneš?
  • Neobmedzený a trvalý prístup k jednotlivým lekciím.
  • Kvalitné znalosti v oblasti IT.
  • Zručnosti, ktoré ti pomôžu získať vysnívanú a dobre platenú prácu.

Popis článku

Požadovaný článok má nasledujúci obsah:

V článku sa zoznámime s pokročilejšími technikami pre paralelné programovanie v jazyku Java. Predstavíme si Bariéru a CountDownLatch.

Kredity získaš, keď podporíš našu sieť. To môžeš urobiť buď zaslaním symbolickej sumy na podporu prevádzky alebo pridaním obsahu na sieť.

Článok pre vás napísal Petr Štechmüller
Avatar
Autor se věnuje primárně programování v Javě, ale nebojí se ani webových technologií.
Aktivity