Diskuze: Parallel For
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 9 zpráv z 9.
//= 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.
z jinych vlaken nemuzes primo modifikovat UI. pristup se musi synchronizovat pres Invoke nebo Dispatcher. Ale ten tvuj navrh je celkove nejak nelogicky protoze nechapu jaky prinos maji ty dalsi vlakna?
Díky za odpověď. Moje stávající aplikace využívá klasickou funkci for V každém cyklu se provádí poměrně složitý a zdlouhavý proces s očekávanými získanými informacemi. Na základě těchto získaných informací se dynamicky vytvářejí ovládací prvky - textboxy, label, picturebox atp. Problém je v neefektivnosti - příliš zdlouhavé. Potřeboval bych celý cyklus zrychlit. Možná je moje představa naivní, ale myslel jsem, že použít pro získání informací více vláken, celý proces urychlí - proto parallel.for.
Ahoj, já bych to rozdělil na dvě části. Složité výpočty bych nechal dělat vedlejší vlákna a textboxy bych vytvářel v hlavním vlákně. Prostě spustíš tu časově náročnou funkci s výpočtem ve vedlejším vlákně a ta ti vrátí výsledek do hlavního vlákna kde s ním naložíš dle libosti (např. vytvoříš ten textbox).
Pokud se nechceš zabývat synchronizací mrkni se na BackgroundWorker, tam to je už vyřešené. Když funkce ve vedlejší vlákně skončí, tak ti to vyhodí v hlavním vlákně event i s výsledným datama který si jen vezmeš a zpracuješ.
jo takhle. no to by uz asi davalo smysl. napsal bych to neco jako:
private void CreateUIForResult(object result){...}
Parallel.For(1, n, Sub(i)
var result=DoCalculation();
this.Invoke(CreateUIForResult(result));
BackgroundWorker je asi pro moji funkci nepoužitelné. Já potřebuji v jednu chvíli (současně) zpracovávat data z více zdrojů - počítačů. V podstatě jde o přístup na vzdálené pc, tam získat data a zobrazit je. Těch pc může být různý počet - 20 až 30. Zatím to funguje v klasické smyčce, ale je to pomalé protože se vždy čeká na zpracování dat z jednoho pc. Pak se začnou zpracovávat data z dalšího atd. Potřeboval bych zjištovat stav na více počítačích současně. Proto hledám nějakou funkci, která bude pracovat paralelně na více zdrojích - parallel.for mi přišlo ideální.
BackgroundWorker můžeš vytvářet dynamicky, takže by neměl být problém s použitím pro libovolný počet paralelních výpočtů. Ale možná že to je pro tvůj případ zbytečně robustní. Každopádně držel bych se toho, že ty funkce bežící ve více vláknech budou provádět jen časově náročné výpočty, ale samotné vykreslování UI bude dělat hlavní vlákno.
BackgroungWorker je super hlavně v tom, že nemusíš řešit synchronizaci vláken, on si toto řeší sám a můžeš ho bez problémů spustit vícekrát...
Zobrazeno 9 zpráv z 9.