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í.

6. diel - Synchronizovaná front a vzor producent - konzument v C ++

V minulej lekcii, Synchronizácie vlákien v C ++ - Volatile a mutex , sme si predstavili std::mutex, teda triedu, ktorá nám dovolí vytvoriť synchronizovaný blok a vďaka ktorej dokážeme sychronizovat vlákna medzi sebou. K tomu sme si vysvetlili, čo je to race condition. Pri deklarovaní premenných tiež nesmieme zabudnúť na kľúčové slovo volatile, ktoré zabezpečia, že hodnota premennej nebude v procesore cachovanie.

Dnes dáme dohromady všetko, čo sme sa zatiaľ naučili. Vytvoríme si synchronizovanú front, na ktoré si vyskúšame mutexy a ich zamykanie v praxi. Až budeme mať synchronizovanú front hotovú, naimplementujeme si jednu z najčastejších viacvláknových architektúr - producent - konzument. Máme pred sebou veľa práce, tak hor sa do toho!:)

Synchronizovaná fronta

Fungovanie fronty poznáme. Ide o tzv. FIFO (First In First Out) dátovú štruktúru. V prípade, že neviete o čom hovorím, odporúčam si pred pokračovaním vo mnohovláknové programovania prejsť základné dátové štruktúry.

Implementovať front nie je zas tak zložité - potrebujeme poľa alebo spájať zoznam. Potom z jednej strany plníme dáta, zatiaľ čo na druhej je natierame. Vo viacvláknové aplikácii bude front plniť niekoľko vlákien nejakými výsledky, čo vypočítala, aby sa využil výkon viac jadier procesora. To bohužiaľ už tak jednoduché nebude.


 

...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 za exkluzívnu cenu 315 kreditov
Aktuálny stav konta 0 kreditov
Kúpou tohoto výhodného balíčku získaš prístup ku všetkým 23 článkom (23 lekcií) s kontrolou a certifikáciou a ešte naviac ušetríš 211 Kč. Ponuka je časovo obmedzená a platí pro všetky lekcie v kurze. Nakúp teraz a získaj limitovanou 40% 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 tutoriálu si v C ++ vytvoríme synchronizovanú front pomocou vlákien, ktorú následne použijeme v architektúre producent - konzument.

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 Patrik Valkovič
Avatar
Věnuji se programování v C++ a C#. Kromě toho také programuji v PHP (Nette) a JavaScriptu (NodeJS).
Aktivity