Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).
V Drupalu byla nalezena a opravena kritická zranitelnost SA-CORE-2026-004 (CVE-2026-9082). Útočník může provádět libovolné SQL dotazy na webech používajících databázi PostgreSQL.
Richard Hughes oznámil, že službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzoruje také společnost HP.
O víkendu proběhla demopárty Outline 2026. Publikována byla prezentovaná dema. Upozornit lze na 16 bajtové, opravdu šestnáct bajtové, zvukově obrazové demo Wake Up! 16b (YouTube).
Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.
Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.
Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.
Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.
Ahoj ,
Poradte prosim ako sa riesi nasledujuci pripad, potrebujem ukoncit cyklus while, ktory je vo vlakne , z ineho vlakna. Skusal som to tak ze nastavujem flag sendStopFlag na true.
Cyklus vsak stihne spravit este jednu iteraciu. Pridanie rsp. zdvojenie podmienky if (sendStopFlag==false) do_something (); sa mi zda ako zle riesenie
sendStopFlag==false;
void * foo_function( void *ptr )
{
while (sendStopFlag==false)
{
usleep(4*1000000);
pthread_mutex_lock( &sr_mutex );
len = fillbuffer(buffer) ;
pthread_mutex_unlock( &sr_mutex );
do_something (); // Ak dojde k nastaveniu sendStopFlag = true mimo vlakna , stale sa vykona
}
fprintf(stderr, "BYE BYE \n ");
do_something2 ();
}
return 4;pthread_cond_signal a producer/consumer problem. To by ti mohlo pomoct.
Popis není moc konkrétní, ale také bych se přiklonil k použití condition variable. Pokud opravdu tu činnost potřebujete periodicky vykonávat po čtyřech sekundách, pak ideální bude použít pthread_cond_timedwait(), což bude mít oproti vašemu řešení nezanedbatelnou výhodu, že pokud dojde k nastavení flagu během čekání, ukončí se smyčka okamžitě a ne až po uplynutí intervalu.
Poznámka: i když je poměrně malá pravděpodobnost, že čtení nebo zápis příznaku nebudou atomické, měl byste chránit čtení proměnné sendStopFlag, do které zapisuje jiný thread, případně použít něco jako libatomic_ops.
Tiskni
Sdílej: