DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   Programiranje (http://www.devprotalk.com/forumdisplay.php?f=23)
-   -   Problem sa threadom- c# (http://www.devprotalk.com/showthread.php?t=4755)

bags 19. 02. 2008. 01:49

Problem sa threadom- c#
 
Imam u programu jednu metodu kojoj je potrebno 10-15 sekundi da odradi neka izracunavanja.Problem je sto korisnik u medjuvremenu treba biti u mogucnosti da koristi program.Naravno stavim tu metodu u poseban thread i kontam gotov problem ali...

Fazon je u tome sto korisnik moze,dok ta metoda vrsi izracunavanje, pozove tu istu metodu sa novim podacima.I sad ja trebam nekako trenutno taj thread prvobitni zaustviti i pokrenuti novi.Sa Abort() nazalost ne radi kako treba.

Ima l neko neki prijedlog?

Thx.

Gruja 19. 02. 2008. 09:50

Standardno resenje je da ta tvoja rutina redovno (npr. u svakom prolazu petlje) proverava neku boolean promenljivu i kad je neko postavi na false da prekine to sto radi. Glavni problem je ako imas duzu IO operaciju, onda nema prekida pre nego sto se ona zavrsi. Tu mozes da probas da zatvaras konekciju iz drugog thread-a i slicno, zavisno sta ti je ta IO operacija.

bags 19. 02. 2008. 11:54

Tako sam ja u sustini i uradio,ali upravo je taj problem sto ne moze trenutno prekinuti thread pa baca exception.Kada sam obradio taj exception sve je ok,ali mislim da je to potecijalno mjesto za probleme u buducnosti.

Djuki 19. 02. 2008. 12:03

Sinoc sam bas citao o Nitima u c# jeziku. Koliko sam razumeo dok ti je aktivna jedna nit druga dobije procesor i pozove istu metodu, tj ima pristup promenjivana i napravi zbrku.

Kôd:

lock (x) {
    //RadiNesto();
}

Ovde je x promenjiva, a lock zakljucava promenjivu dok jedna nit ne zavrsi sa radom i ostale niti ne mogu da pristupe ovoj promenjivoj i naprave ybrku u memoriji. Nadam se da sam pomogao ako sam pogodio sustinu problema.

djipko 19. 02. 2008. 12:23

Ukratko:

Ako se metoda poziva sa NOVIM podacima resenje je uvek sledece:
Kreira se NOVA nit! Uvek! Sinhronizacija ti ne treba! To su dva nezavisna posla i nema veze sto ih radi ista metoda! Nikakvo zaustavljanje ti ne treba!

Ovo znaci da imas metodu:
retObj DoSmth(Obj args)


Fora je da svaki put kreiras novu nit (ali cije je telo ista metoda u kojoj se poziva DoSmth) kad korisnik to zahteva! Konkurencija ti treba samo pri ispisu/upisu izracunatih stvari negde.
Na osnovu tvog opisa samo tako ima smisla koristiti threadove.

SINHORNIZACIJA (lock) je potrebna kad se pristupa istim podacima. Ako se to ne radi sinhronizacija nema smisla

Na osnovu tvog opisa to je jedino sto ti treba - svaki put nova nit koja kad zavrsi posao - umre kako se to strucno kaze!

Gruja 19. 02. 2008. 13:21

Citat:

Originalno napisao bags (Napišite 51455)
Tako sam ja u sustini i uradio,ali upravo je taj problem sto ne moze trenutno prekinuti thread pa baca exception.

Koji je exception, koji thread ga baca i gde? Daj malo vise detalja.

djipko 19. 02. 2008. 16:18

Citat:

Originalno napisao Gruja (Napišite 51458)
Koji je exception, koji thread ga baca i gde? Daj malo vise detalja.

Exception koji baca nije bitan jer je na osnovu opisa problema logika pogresna!
Ako dva threada treba da izvrse istu rutinu nad razlicitim podacima nema nikakvog smisla zaustavljati jedan dok drugi ne zavrsi - jer oni nisu medjusobno zavisni. Zasto kod nije deljeni resurs mislim da ne treba objasnjavati.
Ako pak ta rutina radi nad istim podacima, a u pitanju je citanje tih podataka bez izmene - opet nema smisla bilo kakva sinhronizacija - pod uslovom da ih neki drugo thread ne menja.
Ako ima izmene podataka - koristi se klasican lock-mutex-critical section mehanizam koji pod razlicitim nazivima postoji u svakom programskom jeziku koji podrzava multithreading (ili multithreading bilioteka ih ima uvek).

Mislim da je problem koji kolega ima ne razumevanje rada sa tredovima u potpunosti...
Naravno mozda ja nisam razumeo nesto...

bags 19. 02. 2008. 21:38

Hvala na odgovorima,ali problem je za sada rijesen.

Radilo se o sledecem.Korisnik ima mogucnost da pozove preko gui-a odredjenu metodu.Problem je bio sto se gui zamrzne,dok traju ta izracunavanja.Kada sam stavio tu metodu u poseban thread,sve je radilo ok,osim kad korisnik ponove pozove tu istu metodu.Onda sam ja provjeravao da li je taj thread vec pokrenut,pokusavao ga zaustaviti (jer mi vise nije potreban,a zauzima resurse) i kreirao novi thread.

Jedini problem je bio kad korisnik pomahnita :) i pozove metodu par desetina puta u sekundi.Onda se javaljao InvalidoperationException.


Vreme je GMT +2. Trenutno vreme je 22:32.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.