Pouze tento týden sleva až 80 % na e-learning týkající se PHP. A zároveň využij akce až 30 % zdarma při nákupu e-learningu. Více informací.
Hledáme programátora, 100% home office, 100% flexibilní. Prozkoumej aktuální pozice
discount week 30 - hiring

23. diel - OpenMP - paralelizácie bez manuálneho vytvárania vlákien v C ++

V minulej lekcii, Vektorizácia v C ++ - Restrict ukazovateľ a zarovnanie pamäte , sme pokračovali v téme vektorizácia. Predstavili sme si ukazovateľ restrict a ako optimalizovať zarovnaním pamäte.

Kým pri vektorizáciu sme sa od vlákien posunuli o úroveň nižšie a riešili sme, ktoré inštrukcie procesor vykonáva, tentoraz sa presunieme o úroveň vyššie. Open Multi-Processing (OpenMP) nám totiž dovoľuje program jednoducho paralelizovat, ale pritom za nás vyrieši vytváranie vlákien, ich synchronizáciu a správu. Obdobne ako pri vektorizácia bude táto lekcia len letmým načrtla problému. Podrobnejšie vysvetlenie by totiž vydalo na samostatný kurz. Cieľom tejto lekcie je získať predstavu o OpenMP a hlavne ukázať, že niečo také vôbec existuje.

OpenMP

OpenMP je skratka Open Multi-Processing. Ide o štandard a tak je OpenMP iba popis rozhrania slúžiace k paralelizáciu programu - v tomto prípade definuje direktívy pre prekladač (časť kódu začínajúce mriežkou), ktoré následne vygenerujú Paralelizované kód.


 

...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ť lekcie a funkcie postupne a po jednom 210 bodov
Kúpiť všetky aktuálne dostupné lekcie s funkciou odovzdávanie úloh za exkluzívnu cenu 179 bodov (447 Kč)
Na svojom účte máš aktuálne 0 bodov
Kúpou tohoto výhodného balíčku získaš prístup ku všetkým 23 lekciím s kontrolou a certifikáciou a ešte naviac ušetríš 78 Kč. Ponuka je obmedzená len pre prvé lekcie z kurzu a obsahuje exkluzívnu zľavu 15%.
179 bodov získaš za pridanie svojho článku na sieť alebo za 524 Kč 447 Kč

Pozor, pokiaľ si kúpiš len tuto lekciu, stratíš nárok na špeciálnu zľavu 15% na balíček všetkých lekcií.

Kúpiť len lekcii 10 bodov
Na svojom účte máš aktuálne 0 bodov
10 bodov získaš za pridanie svojho článku na sieť alebo za 25 Kč

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 C ++ tutoriálu sa od vlákien presunieme vyššie a pozrieme sa na štandard OpenMP, ktorý za nás spravuje vlákna a program paralelizujú.

Body 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