abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:44 | Nová verze

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Nová verze

    Byla vydána nová verze 6.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.14.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | Nová verze

    Byla vydána nová verze 30.0.0 frameworku pro vývoj multiplatformních desktopových aplikací pomocí JavaScriptu, HTML a CSS Electron (Wikipedie, GitHub). Chromium bylo aktualizováno na verzi 124.0.6367.49, V8 na verzi 12.4 a Node.js na verzi 20.11.1. Electron byl původně vyvíjen pro editor Atom pod názvem Atom Shell. Dnes je na Electronu postavena celá řada dalších aplikací.

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Nová verze

    Byla vydána nová verze 9.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 220 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    včera 23:22 | IT novinky

    Evropský parlament dnes přijal směrnici týkající se tzv. práva spotřebitele na opravu. Poslanci ji podpořili 584 hlasy (3 bylo proti a 14 se zdrželo hlasování). Směrnice ujasňuje povinnosti výrobců opravovat zboží a motivovat spotřebitele k tomu, aby si výrobky nechávali opravit a prodloužili tak jejich životnost.

    Ladislav Hagara | Komentářů: 2
    včera 16:11 | Nová verze

    Bylo oznámeno (cs) vydání Fedora Linuxu 40. Přehled novinek ve Fedora Workstation 40 a Fedora KDE 40 na stránkách Fedora Magazinu. Současně byl oznámen notebook Slimbook Fedora 2.

    Ladislav Hagara | Komentářů: 8
    včera 13:44 | Upozornění

    ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.

    Ladislav Hagara | Komentářů: 18
    včera 13:33 | Komunita

    Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | Nová verze

    Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (10%)
     (2%)
     (17%)
    Celkem 705 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: [Python] Jak na mezivlaknove callbacky?

    28.8.2014 20:48 David Sedláček | skóre: 20 | Žďár nad Sázavou
    [Python] Jak na mezivlaknove callbacky?
    Přečteno: 737×
    Ahojte, ve sve aplikaci celkem dost pouzivam callbacky.

    Ale zacinam narazet na problemy s mezivlaknovym volanim. PyQt obcas spadne, kdyz se napr widget manipuluje z callbacku v jinem threadu, nez ve kterem byl vytvoren.

    Jak resit problemy s mezivlaknovymi callbacky? Resp jak osetrit, aby se callback volal ze stejneho threadu, ve kterem byla vytvorena instance tridy?

    Nejaky vzor ci neco podobneho - urcite nejsem sam, kdo ma podobny problem.

    Odpovědi

    29.8.2014 07:43 petr b
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Ahoj, já sice dělám ve wxPythonu, ale tam je stejný problém. Teda on to ani tak není problém jako vlastnost. Platí, že to co dělám v UI musí být v jednom threadu, a když už mám threadů víc, tak posílám eventy. Případně eventy v kombinaci s frontou.
    # Muj vlastni super event, ktery dela super veci
    (SuperEvent, EVT_SUPER) = wx.lib.newevent.NewEvent()
    # ...
    wx.PostEvent(target_window, super_event_instance)
    
    což je zamozřejmně wx-specific, ale v QT to bude dost podobné.

    A k tomu případně import Queue
    29.8.2014 15:25 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Aplikaci bych chtel co nejvice v Pythonu. Asi chapu, kam miris, ale musel bych vyuzit qt threading. Podle toho co jsem pochopil z diskusi na netu.

    Ta fronta je zajimavy napad. Stale premyslim, jak spousteni tasku managujicich gui zajistit pouze z jednoho hlavniho threadu. Problem vidim v tom, ze Qt ten thread spolkne cely a otazka je, jak do nej napasovat management te fronty tasku.
    pavlix avatar 31.8.2014 20:40 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Předpokládám, že má Qt stejně jako ostatní podobné frameworky nějaký main loop, do kterého se dají přidávat další události založené na souborových deskriptorech. Potom je v Pythonu potřeba využívat prostředků, které ty souborové deskriptory nabízejí. Za tím celým je stejně nějaké jednoduché zavolání select/poll/epoll syscallu.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    29.8.2014 08:59 Ivan
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    I v QTcku je to tak. S UI by melo pracova poze hlavni vlakno. Navic v QTco ka kazdy object tzv. tread afinity, tzn kazdy objekt si pamatuje kontext vlakna ve kterem byl vytvoren. Pokud zavolas connect na dva objekty z ruznych vlaken, tak QTcko samo pochopi, ze se zprava musi predavat mezi vlakny.

    Asi pri precti tohle: http://blog.qt.digia.com/blog/2010/06/17/youre-doing-it-wrong/ http://woboq.com/blog/qthread-you-were-not-doing-so-wrong.html
    29.8.2014 15:21 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    V QT, potazmo s Pythonem delam asi dva tydny. Muzes mi prosim naznacit nejake reseni?

    QT jsem chtel pouzit pouze na GUI a zbytek psat pouze v Pythonu (threading). Vsak tohle muselo resit X lidi predemnou?
    1.9.2014 11:05 Ivan
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Ja zase neznam Python :(. Kazdopadne aby to vybec mohlo fungovat asychronne tak:
    - hlavni vlakno musi procesovat QT event loop
    - pak potrebujes alespon jedno dalsi vlakno vytvorene pomoci QT knihovny, tohle vlakno muze posilat eventy do vlavniho UI threadu.
    - ostatni vlakna (non-QT) budou vkladat udalosti do fronty(chranene mutexem), background QT thread je bude vyzvedavat a preposilat(emit) dal.
    Asi by to slo i jednoduseji, ale tomu QT se nevyhnes. Protoze to co se posila pres emit musi byt potomek QObjektu a navic to musi byt registrovany QT-meta objekt a navic to musi byt "klonovatelne". Pokus zavolas emit v jednom vlakne, tak se do druheho vlakna doruci kopie.
    1.9.2014 11:21 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    No nakonec jsem to v ramci rychlosti a relativni jednoduchosti vyresil vyuzitim QThread (viz muj prispevek na konci vlakna)

    Muzu v klidu pracovat v Pythonu a pokud chci sahat do Qt GUI, pouziju tu tridu, ktera je potomkem QThread. A nemotam do Py jadra aplikace Qtcko.
    29.8.2014 15:32 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Na druhou stranu volat Qt thread z nahodilych threadu tez neni moc stastne. Ale chtel bych poznat nejake pure-Python reseni bez Qt threadingu.
    30.8.2014 14:18 Jardik
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Fronta, zamykat mutexem zapis/cteni a nejak to integrovat do event loopu z Qt, takze Qt se tedy uplne nevyhnes. Qt totiz ma jakousi event loopu, kde ceka na nove eventy a pak podle toho neco vola. A Qt pak musi vedet, ze mas nejakou frontu, kde kdyz neco je, ze ma Qt neco zavolat. A nebo treba pouzit nejaky ten Qt timer, pokud nezalezi na rychlosti, ale pokud chces frontu kontrolovat v nejakym intervalu a nezalezi moc na presnosti.
    31.8.2014 20:17 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Tak jsem to nakonec vyresil takovou "proxynou"
    class PyQtProxyThread(QThread):
        __signalName = 's'
        def __init__(self, _destinationCallable, _data):
            assert callable(_destinationCallable)
            QThread.__init__(self)
            self.__data = _data
            self.connect(self, SIGNAL(self.__signalName), _destinationCallable)
            self.start()
    
        def __del__(self):
            self.wait()
    
        def run(self):
            self.emit(SIGNAL(self.__signalName), self.__data)
    skunkOS avatar 2.9.2014 10:35 skunkOS | skóre: 27 | blog: Tak nějak
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    // Volano z gui vlakna, treba z hlavniho okna aplikace.
    QThread *thread = new QThread;
    Worker *pracovnik = new Worker(); // pracovnik dedi QObject
    pracovnik->moveToThread(thread);
    
    // A ted pokud potrebujes predávat data z pracovnika (ktery bezi na jinem vlakne) do hlavniho vlakna, tak to delej pres signaly.
    connect(pracovnik, SIGNAL(abc()), this, SLOT(abc()));
    
    Jak bylo řečeno, connect() automaticky pozna, že slot se nachazi v jinem vlakně nez signal a provede automaticky mezivlaknovej invoke.
    http://martinrotter.github.io
    2.9.2014 11:13 Ivan
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Jinak jeste jeden tip, pokud pouzivas Linux. Pokud bys' opravdu chtel sahat na GUI z ostatnich vlaken tak bys' mel jeste zavolat neco jako QCoreApplication::setAttribute(Qt::AA_X11InitThreads); hned pri startu aplikace. Pokud to neudelas, tak muzes sestrelit Unity (anebo jiny WM) popr. muze umrit tvoje aplikace. Xlib byla katastrofa (co se multithreadingu tyce) a XCB na tom neni o moc lip.

    Jardík avatar 4.9.2014 16:35 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Pokud to neudelas, tak muzes sestrelit Unity (anebo jiny WM) popr. muze umrit tvoje aplikace
    Ano, tvoje aplikace umřít může, ale to, že sestřelíš Unity či jiný WM je samozřejmě krávovina, leda by byl zabugovaný. Kecáš totiž přes socket s Xkama, popř. něco přes sdílenou paměť (třeba obrázky) a X server potom s WM úplně jiným socketem. A to, jestli je tvoje aplikace vícevláknová pro WM neznamená vůbec žádný problém.
    Věřím v jednoho Boha.
    Josef Kufner avatar 4.9.2014 17:10 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Aby jsi se nedivil. Těch chyb v X serveru a desktopových prostředích je kopec. Pokud tvoje aplikace začne komunikovat příliš zvrhle, může nějakou najít a poslat celý desktop k zemi. Obzvlášť OpenGL hry v kombinaci s příliš syrovými drivery by mohly vyprávět.
    Hello world ! Segmentation fault (core dumped)
    5.9.2014 20:10 Jardík
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Tak takové chyby je třeba řešit. Ale pochybuju, že nějak souvisí s tím, že je aplikace vícevláknová a používá nějaké xlib či xcb špatně, protože to stejně všechno leze přes socket. A na chybný X request (kvůli patlálo matlálo zapisování dat z více vláken najednou) by měl x server odpovědět patřičnou chybou či klienta odpojit, nikoliv spadnout.
    5.9.2014 20:12 Jardík
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Jinak o miliónech race condition v samotném návrhu X protokolu už bylo napsáno taky mnoho. Pokud s tím aplikace nepočítají, jejich programátor to neví, atd, tak je to problém.
    5.9.2014 14:24 Ivan
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Samozrejme ze je to kravovina, bohuzel je to i smutny fakt :(. WM "odposlouchava" komunikaci aplikace s Xkama a casto ma nejake predpoklady. Pokud se ty predpoklady nesplni, tak se zacnou dit divny veci. Napriklad Unity lze (anebo spis slo) sestrelit tim, ze aplikace pridavala a odebirala polozky se sveho menu (namisto toho aby je jen prejmenovavala anebo shovavala). Takze kdyz se z menu odebirala a zase pridavala polozka "Tools" tak mela pokazde jine id. Bohuzel Unity, kdyz posloucha Xeventy, tak se chyta na oboji, jak jak na jmeno polozky v menu, tak a i na to ID.

    Dalsi problem muze nastat kdyz menis kurzor z normalniho na presipaci hodiny (a nazpatek), bez tyhle volby se muze stat, tak uz ten normalni kurzor(sipka) nejde vratit.
    8.9.2014 19:05 Ivan
    Rozbalit Rozbalit vše Offtopic: Re: [Python] Jak na mezivlaknove callbacky?
    Kdyz tak o tom premyslim, tak ten priklad s menu je blbost. Unity ma navic svuj vlastni plugin primo v QT knihovne, v tom priklade s menu se sral ten qt plugin. Jinak jen priklad co jsem uvadel nakonec zavola funkci "XInitThreads" z xlib/xcb, ktera rekne te knihovne, ze bude pouzivana v multi-threaded modu(neni to default) - bez toho nedojne k inicializaci nejakych zamku.

    6.9.2014 21:33 David Sedláček | skóre: 20 | Žďár nad Sázavou
    Rozbalit Rozbalit vše Re: [Python] Jak na mezivlaknove callbacky?
    Aplikace na 99 % pojede jen na Xkach, WM manager nastesti nepotrebuju, ale dobre vedet, ze se neco takoveho muze stat. By me nenapadlo ze muzu svou app sestrelit WM? !!?!!

    Založit nové vláknoNahoru

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

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.