Diskuze: Uvolnění paměti
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
O uvolnění paměti se až na výjimky ve vysokých jazycích vůbec nestaráš, děje se plně automaticky. Pokud trvá příliš dlouho, měl by jsi se zamyslet nad tím, jaké instance si držíš v paměti a jestli je tam vážně potřebuješ. Do proměnné stačí např. pouze přiřadit null, uvolnění potom proběhne po nějaké době samo, až se to C# bude hodit. Více čtení pod klíčovým slovem Garbage Collector.
EDIT: Ještě jsem si vzpomněl, že se v C# nějak musí řešit sdílení připojení a obalení určitých volání přes using bloky, aby docházelo k uvolňování zdrojů. Měl by tu být dostatek seriálů podle kterých si zkontroluješ zda to děláš právně.
Zkus přepnout debug na release a pak aplikaci spustit .exem z bin/release místo z VS , jestli se to bude chovat stejně.
Zkusil jsem to přepnout i na release, ale nic nepomohlo. Pokoušel jsem se využít právě Garbage Collector a ten mi v mnoha věcech pomohl. Ale ikdyž dávám všude nejdříve inicializaci, tak místo uvolňování paměti si to bere čím dál více. Já se snažím i pokud není nutné, tak mít datasety prázdné, ale evidentně v tom nejsem všude úspěšný. Ale děkuji za rady.
Pokud ti aplikace bezi i po "ukonceni" aplikace, je to pravdepodobne tim, ze tam poustis (ty , nebo neco pdotim) nejaky paralelni thread, ktery ma nastaveny IsBackground = false... v tom okamžiku i když ukončíš hlavní thread s render threadem (zavřeš aplikaci), framework čeká, než skončí všechny thready (všechny "foreground" thready).
Koukni se jestli někde v kódu nemáš new Thread() to implicitně vytváří foreground thread
Nepoužívám je všude hlavně ne v TCP spojení, ale asi je budu muset nějak začlenit, ale podle mně je problém ten, že mám v aplikaci několik dynamicky vytvořených záložek, kde mám UserControly a v nich jsou datasety, které nevím jak vyprázdnit při rušení záložky. Používám totiž komponenty DevComponents pro WFA a tam když má záložka tlačítko ukončit (zavřít), tak nejsem schopen odchytit tu událost a nějak se o to postarat.
Budu tipovat - děláš větší množství záložek a máš v nich datasety
s větším množstvím dat, že?
Desetitisíce záznamů tohle způsobit nemůžou, ale statisíce nebo miliony
už ano.
Ty návrhy od ostatních nahoře jsou k ničemu, protože tenhle problém
nemůže způsobit nic, co by vyřešily postupy, které uvádějí.
Ani s garbage collectorem to nesouvisí, to by se to chovalo jinak.
Problém je v datasetu, který funguje jako transakční in-memory
databáze.
Dataset se váže na vizuální komponentu, která zprostředkovává in-memory
CRUD operace s podporou transakcí.
Ve chvíli, kdy dáš zavřít okno, se posílají události na uložení
datasetů, což způsobí jeho duplikování (proto paměť skočí na
dvojnásobek), porovnání změn a uložení (proto to trvá hrozně
dlouho).
Ta vtipná část je, že to ani nemusíš dělat ručně, vizuální komponenty
tohle mají tendenci dělat samy přes bindingy.
Potřebuješ si pečlivě pročíst dokumentaci, jak se která komponenta a dataset chovají, vypnout trackování změn a před zavřením okna zakázat ukládání. A to dokonce i v případě, že nic takového neděláš, protože se to děje samo.
Zobrazeno 8 zpráv z 8.