Lekce 5 - CoroutineScope a ukončení běhu coroutines v Kotlin
V minulé lekci, Dispatchers a CoroutineContext v Kotlin, jsme si popsali dispatchers v Kotlin a ukázali si, jak je můžeme v našich aplikacích využít.
V dnešním Kotlin tutoriálu zaměřeném na
coroutines se budeme věnovat strukturované
paralelnosti. Představíme si další důležitý koncept pro práci s
více coroutines, CoroutineScope
. Na praktických příkladech si
pak vysvětlíme, o co se jedná a jak s ním pracovat.
Strukturovaná paralelnost
Představme si, že bychom například začali stahovat z externího zdroje (např. z internetu) sto souborů. V polovině stahování bychom se ale rozhodli, že už tyto soubory nepotřebujeme, protože například uživatel ukončil stahování. Pro každý stahovaný soubor jsme předtím vytvořili samostatnou coroutine a teď bychom je chtěli všechny pozastavit. Jak bychom to dokázali vyřešit?
Ukončení běhu coroutines
Pojďme si tedy ukázat několik způsobů, jak nepotřebné coroutines ukončit.
Uložení coroutines do kolekce
Jedna možnost, která nás mohla napadnout, je vytvořit kolekci
List
. Do té bychom ukládali všechny instance Job
,
které dostaneme voláním launch
. Pokud nebudeme chtít nadále
stahovat soubory, zavoláme na každou
...konec náhledu článku...
Pokračuj dál
Došel jsi až sem a to je super! Věříme, že ti první lekce ukázaly něco nového a užitečného.
Chceš v kurzu pokračovat? Přejdi do prémiové sekce.
Koupit tento kurz
Obsah článku spadá pod licenci Premium, koupí článku souhlasíš se smluvními podmínkami.
- Neomezený a trvalý přístup k jednotlivým lekcím.
- Kvalitní znalosti v oblasti IT.
- Dovednosti, které ti pomohou získat vysněnou a dobře placenou práci.
Popis článku
Požadovaný článek má následující obsah:
V Kotlin tutoriálu se budeme věnovat strukturované paralelnosti. Naučíme se pracovat s CoroutineScope, který umožňuje ukončit několik coroutines najednou.
Kredity získáš, když podpoříš naši síť. To můžeš udělat buď zasláním symbolické částky na podporu provozu nebo přidáním obsahu na síť.