IT rekvalifikace s garancí práce. Seniorní programátoři vydělávají až 160 000 Kč/měsíc a rekvalifikace je prvním krokem. Zjisti, jak na to!
Hledáme nové posily do ITnetwork týmu. Podívej se na volné pozice a přidej se do nejagilnější firmy na trhu - Více informací.

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.

Kúpiť tento kurz

Kúpiť všetky aktuálne dostupné lekcie s funkciou odovzdávanie úloh iba za 525 kreditov
Aktuálny stav konta 0 kreditov
Kúpou tohoto balíčku získaš prístup ku všetkým 23 článkom (23 lekcií) tohoto kurzu.

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