Zemřel Scott Adams, tvůrce komiksových stripů Dilbert parodujících pracovní prostředí velké firmy.
Sdružení CZ.NIC vydalo novou verzi Knot Resolveru (6.1.0). Jedná se o první vydanou stabilní verzi 6, která je nyní oficiálně preferovanou a doporučovanou verzí, namísto předešlé verze 5. Více o Knot Resolveru 6 je možné se dočíst přímo v dokumentaci.
Byl vydán Linux Mint 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.
Wine bylo po roce vývoje od vydání verze 10.0 vydáno v nové stabilní verzi 11.0. Přehled novinek na GitLabu. Vypíchnuta je podpora NTSYNC a dokončení architektury WoW64.
Byl vydán Mozilla Firefox 147.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Firefox nově podporuje Freedesktop.org XDG Base Directory Specification. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 147 bude brzy k dispozici také na Flathubu a Snapcraftu.
Asociace repair.org udělila anticeny těm nejhorším produktům představeným na veletrhu CES 2026. Oceněnými jsou například šmírující kamery Amazon Ring AI, chytrý běžecký pás od společnosti Merach, která otevřeně přiznává, že nedokáže zabezpečit osobní data uživatelů, případně jednorázové lízátko, které rozvibrovává čelisti uživatele a tak přehrává hudbu. Absolutním vítězem je lednička od Samsungu, která zobrazuje reklamy a kterou lze otevřít pouze hlasovým příkazem přes cloudovou službu.
Íránští protirežimní aktivisté si všímají 30% až 80% ztráty packetů při komunikaci se satelity služby Starlink. Mohlo by se jednat o vedlejší důsledek rušení GPS, kterou pozemní přijímače Starlinku používají k výpočtu polohy satelitů a kterou se režim rovněž snaží blokovat, podle bezpečnostního experta a iranisty Amira Rashidiho je ale pravděpodobnější příčinou terestrické rušení přímo satelitní komunikace Starlinku podobnou
… více »Evropská komise (EK) zvažuje, že zařadí komunikační službu WhatsApp americké společnosti Meta mezi velké internetové platformy, které podléhají přísnější regulaci podle unijního nařízení o digitálních službách (DSA). Firmy s více než 45 miliony uživatelů jsou podle DSA považovány za velmi velké on-line platformy (Very Large Online Platforms; VLOP) a podléhají přísnějším pravidlům EU pro internetový obsah. Pravidla po
… více »Tržní hodnota technologické společnosti Alphabet poprvé v historii přesáhla čtyři biliony dolarů (83 bilionů Kč). Stalo se tak poté, co Apple oznámil, že bude na poli umělé inteligence (AI) spolupracovat s dceřinou firmou Alphabetu, společností Google.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 161 (pdf).
Ahoj,
mám problém se signály a sloty. Mám vytvořené dvě třídy ve dvou vláknech (pomocí Thread run). V jednom vláknu získávám data a po zpracování se je snažím předat druhému vláknu pomocí signálu a slotu. Pro data mám vytvořenou vlastní strukturu.
Vše se zdá, že funguje (žádné hlášení při kompilaci). Při spuštění se data opravdu přesouvají z jednoho vlákna do druhého. ALE při zrušení aplikace(třídy A) vypíše QT následující hlášku:
Qt has caught an exception thrown from an event handler. Throwing exceptions from an event handler is not supported in Qt. You must reimplement QApplication notify() and catch all exceptions there.
(po reimplementaci notify jsem obdrzel stejnou hlasku).
Díky za každou odpověd!!!
Přidávám dulezite casti kodu:
class Global{
typedef struct mStruct{
int promenna;
int promenna2;
}mStruct;
};
Q_DECLARE_METATYPE(GFunction::mStruct)
class B{
signal:
mSignal(Global::mStruct);
};
class A:QThread{
~A{
this->terminate();
QThread::wait() ;
}
void run(){
B b;
qRegisterMetaType<Global::mStruct> ("Global::mStruct");
connect(&b,SIGNAL(mSignal(Global::mStruct)),this,SLOT(mSlot(Global::mStruct)));
exec();
}
slot:
mSlot(Global::mStruct){}
};
Tak jsem zjistil,
že tu varovnou hlášku způsobuje pravděpodobně exec(), ale nevím co místo něj použít, možná eventloop???
Tak po dlouhém hledání a zkoušení různých věcí jsem zjistil, že problém dělá ukončování vlákna.
Je nutné použít this->quit(); potom uz hláška nevyskočí a vše je korektní.
Z toho kódu co je přiložený není úplně zřejmé, jakým způsobem máš obě třídy vytvořené, ale s největší pravděpodobností vůbec nemusíš ve třídě A dědit QThread. Někdy v Qt4.4 se totiž změnil způsob práce s QThread a nyní je to spíš interface, pomocí kterého se s vlákny manipuluje.
Dokumentace bohužel tuhle "malou" změnu nějak nereflektuje a neobsahuje korektní příklad použití.
Jak správně použít QThread je třeba tady.
Tiskni
Sdílej: