Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 211. sraz, který proběhne v pátek 19. září od 18:00 ve Studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Na srazu proběhne přednáška Jiřího Eischmanna o nové verzi prostředí GNOME 49. Nemáte-li možnost se zúčastnit osobně, přednáškový blok bude opět streamován živě na server VHSky.cz a následně i zpřístupněn záznam.
Microsoft se vyhnul pokutě od Evropské komise za zneužívání svého dominantního postavení na trhu v souvislosti s aplikací Teams. S komisí se dohodl na závazcích, které slíbil splnit. Unijní exekutivě se nelíbilo, že firma svazuje svůj nástroj pro chatování a videohovory Teams se sadou kancelářských programů Office. Microsoft nyní slíbil jasné oddělení aplikace od kancelářských nástrojů, jako jsou Word, Excel a Outlook. Na Microsoft si
… více »Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.
Správcovský tým repozitáře F-Droid pro Android sdílí doporučení, jak řešit žádosti o odstranění nelegálního obsahu. Základem je mít nastavené formální procesy, vyhrazenou e-mailovou adresu a být transparentní. Zdůrazňují také důležitost volby jurisdikce (F-Droid je v Nizozemsku).
Byly publikovány informace o další zranitelnosti v procesorech. Nejnovější zranitelnost byla pojmenována VMScape (CVE-2025-40300, GitHub) a v upstream Linuxech je již opravena. Jedná se o variantu Spectre. KVM host může číst data z uživatelského prostoru hypervizoru, např. QEMU.
V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.
Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.
Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.
Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
class Thread{ private: pthread_t m_tHandle; unsigned int m_nStatus; Mutex m_tMutex; public: enum Status{ NotRunning = 0, Running = 1, Suspended = 2, Zombie = 3 }; Thread(); virtual ~Thread(); void run(); void kill(); void wait(); pthread_t handle() const { return m_tHandle; }; void handle( pthread_t handle ) { m_tHandle = handle; } void lock() { m_tMutex.lock(); } void unlock(){ m_tMutex.unlock(); } bool tryLock(){ return m_tMutex.tryLock(); } void status( unsigned int status ); unsigned int status() const { return m_nStatus; } virtual void start(); virtual void stop(); static void waitForAll(); }; static void *entry_point(void *thread_) { Thread* thread = reinterpret_cast<Thread*>(thread_); signal(SIGQUIT, signal_handler_SIGQUIT); thread_list_mutex.lock(); thread_list.insert( std::make_pair(pthread_self(), thread) ); thread_list_mutex.unlock(); thread->handle(pthread_self()); thread->start(); thread->stop(); thread->status(Thread::Zombie); pthread_exit(NULL); return NULL; } void Thread::run() { if( status() == NotRunning ) { label_create: status(Running); pthread_create(&m_tHandle, NULL, &entry_point, this); } else if( status() == Zombie ){ wait(); goto label_create; } }Ve funkci
static void *entry_point(void *thread_)
volám thread->start()
. Problém je, že se vždy zavolá metoda start() třídy Thread a né metoda odvozené třídy MujThread
:
class MujThread: public Thread{ public: MujThread(){} virtual ~MujThread(){} virtual void start() { printf("MujThread start()\n"); while(true); } virtual void stop() { printf("MujThread stop()\n"); } };
(Thread*)thread_
, bezúspěšně. Vím ale, že ten kód ještě nedávno fungoval. Pomalu bych řekl, že přestal fungovat po aktualizaci gcc.
pure virtual method called terminate called without an active exception ./testutk: line 4: 6543 Neúspěšně ukončen (SIGABRT)
make clean
.
MujThread::start()
nedávat jako inline. Kompilátor by sice měl být dost chytrý, aby buď ignoroval evidentní chybu programátora, nebo protestoval, jenže právě to ignorování chyby lze provést dvěma způsoby: buď bude ignorovat virtual
nebo inline
(zde implicitní). Musel bych se podívat, co v takové situaci předepisuje specifikace jazyka, ale v každém případě bude jistější nepožadovat po překladači něco, co je principiálně nemožné.
MujThred::start()
jako inline, nefunguje to. Mám jinou třídu (Application):
class Application{ .... public: .... virtual bool onInit() { return true; } virtual void onQuit() {} .... };Od té odvozuji
TestApplication
:
class TestApplication: public Application{ protected: MujThread t; public: virtual bool onInit() { ... t.run(); return true; } virtual void onQuit() { t.kill(); } };Zde však volání virtuálních metod funguje správně, což popírá vaši domněnku. (Už jste viděl zdrojový kód Qt knihovny? Je tam toho plno.) Problém bude nejspíš jinde. A jak říkám výše, ten kód fungoval naprosto bezchybně, když jsem ho před časem použil (ale na jiné distribuci, s jiným kernelem - 2.6.17, teď 2.6.18 - a s trochu nižší verzí GCC).
Thread::run()
(viz. kód výše), konkrétně se zavolá po vytvoření nového vlákna: pthread_create(&m_tHandle, NULL, &entry_point, this)
.
Tiskni
Sdílej: