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
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
Obsah článku spadá pod licenciu Premium, kúpou článku súhlasíš so zmluvnými podmienkami.
- 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ť.