Portál AbcLinuxu, 7. května 2025 19:46

Dotaz: PyQt4 + vlakna = zamrzanie

andree avatar 28.10.2008 11:28 andree | skóre: 39 | blog: andreeeeelog
PyQt4 + vlakna = zamrzanie
Přečteno: 305×
Odpovědět | Admin
hi all,

mam tu taky problem, s ktorym si vobec neviem dat rady...

O co ide - mam aplikaciu (QuantumGIS), ktory ma nejake to python rozhranie, ktorym sa daju vyrabat pluginy.. ten plugin do okna aplikacie vrazi QDockWidget a vsetko funguje fajn... az do okamihu, ked sa pokusim spustit vlakno:
class Gatherer(QThread):
	def __init__(self, parentThread,  controller):
		QThread.__init__(self,  QThread.currentThread())
		self.controller=controller
		
	def run(self):
		self.stopMe=0
		while (self.stopMe==0):
			print '.'
			time.sleep(1)
			print 'xx'
	
	def stop(self):
		self.stopMe=1
		QThread.wait(self)
jedine co to vypise v konzoli je jedna '.', a potom to 'zamrzne'. 'xx' to vypise az potom, ako sa nieco udeje v tom dockwidgete (napr. sa stlaci nejake tlacidlo - predpokladam ze hocikedy, ked sa vola 'handler' nejakeho signalu).

Neviete niekto, kde by mohol byt problem? Ked ten thread spustim priamo:
	g=Gatherer()
	g.run()
	time.sleep(10)
	g.stop()
tak to samozrejme funguje...

Najzaujimavejsie na tom vsetkom je, ze toto:

http://trac.reprojected.com/qgisplugins/browser/trunk/threading_demo funguje uplne spolahlivo - pritom jediny rozdiel je, ze tam to vlakno este vytvara nejake signaly a ze miesto dockwidgetu sa tam zobrazuje okno...

Jedina moznost co ma napada je, ze to vlakno nebezi preto, ze by, pokial nie su spravy od Qt, nebezal ten python interpreter (co by ale bolo divne, ked clovek od neho chcel vlakno...).

any ideas?
Nástroje: Začni sledovat (2) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

andree avatar 28.10.2008 11:32 andree | skóre: 39 | blog: andreeeeelog
Rozbalit Rozbalit vše Re: PyQt4 + vlakna = zamrzanie
Odpovědět | | Sbalit | Link | Blokovat | Admin
este poznamka - ked tam ten time.sleep(1) zrusim, tak to sice vypisuje '. \n xx \n' - akurat ze pre zmenu vobec nereaguje UI toho quantum gisu... ja to nechapem :-/
andree avatar 28.10.2008 15:17 andree | skóre: 39 | blog: andreeeeelog
Rozbalit Rozbalit vše Re: PyQt4 + vlakna = zamrzanie
Odpovědět | | Sbalit | Link | Blokovat | Admin
ok, mozno to nebude nik vediet aj tak - kazdopadne sa mi to podarilo obijst pridanim takehoto kodu:
	self.timer = QTimer()
	QObject.connect(self.timer, SIGNAL("timeout()"), self.runStatus)
	self.timer.start(10)

...

def runStatus(self):
	self.thread.msleep(1)
	return
ak by mi niekto bol schopny logicky objasnit, preco je toto nutne, aby vlakna fungovali (a preco to nie je v ziadnej dokumentacii), bol by som velmi vdacny :-)
Fuky avatar 28.10.2008 16:01 Fuky | skóre: 52 | blog: 4u
Rozbalit Rozbalit vše Re: PyQt4 + vlakna = zamrzanie
Odpovědět | | Sbalit | Link | Blokovat | Admin
Zkoušel jsi místo time.sleep() použít přímo metodu sleep() z třídy QThread?
-- RÁMO: psí tábor , ETriatlon: Výuka plavání
andree avatar 28.10.2008 21:41 andree | skóre: 39 | blog: andreeeeelog
Rozbalit Rozbalit vše Re: PyQt4 + vlakna = zamrzanie
yop, je fakt ze toto je trosku premiesany kod - kazdopadne hociaka kombinacia (aj nekombinacia :)) QThread+threading robi to iste...
msk avatar 29.10.2008 15:42 msk | skóre: 27 | blog: msk
Rozbalit Rozbalit vše Re: PyQt4 + vlakna = zamrzanie
Odpovědět | | Sbalit | Link | Blokovat | Admin
Kto a ako vola ten thread? Nikde to volanie nevidim...
andree avatar 30.10.2008 11:26 andree | skóre: 39 | blog: andreeeeelog
Rozbalit Rozbalit vše Re: PyQt4 + vlakna = zamrzanie
aha... no spusta sa to zo signal handleru - vola sa to uplne standardne: t=Gatherer(); t.start()...

sranda je, ze nasledujuci workaround to "zfunkcni", a ja vobec netusim preco by mal (ako je mi jasne co to robi, a preco by to mohlo fungovat - ale nechapem, preco je nutne toto spravit, aby fungovali vlakna.. by clovek povedal, ze vlakna su od toho, ze funguju same - nie ze si clovek musi preempciu dokodit sam :)))
def someSignalHandler(self):
	self.t=Gatherer()
	self.t.start()

	self.timer = QTimer()
	QObject.connect(self.timer, SIGNAL("timeout()"), self.runStatus)
	self.timer.start(10)

def runStatus(self):
	self.gatherer.msleep(1)
	return

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.