V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.
Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.
Česká národní banka (ČNB) nakoupila digitální aktiva založená na blockchainu za milion dolarů (20,9 milionu korun). Na vytvořeném testovacím portfoliu, jehož součástí jsou bitcoin, stablecoiny navázané na dolar a tokenizované depozitum, chce získat praktickou zkušenost s držením digitálních aktiv. Portfolio nebude součástí devizových rezerv, uvedla dnes ČNB v tiskové zprávě.
Apple představil iPhone Pocket pro stylové přenášení iPhonu. iPhone Pocket vzešel ze spolupráce značky ISSEY MIYAKE a Applu a jeho tělo tvoří jednolitý 3D úplet, který uschová všechny modely iPhonu. iPhone Pocket s krátkým popruhem se prodává za 149,95 dolarů (USA) a s dlouhým popruhem za 229,95 dolarů (USA).
Byla vydána nová stabilní verze 7.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 142. Přehled novinek i s náhledy v příspěvku na blogu.
Společnost Epic Games vydala verzi 5.7 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Intel vydal 30 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20251111 mikrokódů pro své procesory.
Byla vydána říjnová aktualizace aneb nová verze 1.106 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.106 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Canonical pro své zákazníky, předplatitele Ubuntu Pro, prodloužil podporu Ubuntu LTS z 12 let na 15 let (Legacy add-on). Týká se verzí od 14.04 (Trusty Tahr).
Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 5.0.0. Nově je oficiálně podporován Linux ARM64/AArch64. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Ahoj,
v souvislosti s diskuzi Metody pristupu na seriovy port v C jsem se rozhodl resit to pres vlakna. Chtel jsem to udelat tak, ze by kazda instance tridy vytvorila dve vlakna - jedno pro RX, druhe pro TX.
Bohuzel jsem narazil na problem nevim jak vytvorit vlakno, ktere se vytvori s "main" funkci, ktera je metodou dane tridy:
Udelal jsem jednoduchy example:
#ifndef _TRIDA_H_
#define _TRIDA_H_
#include <iostream>
#include <pthread.h>
using namespace std;
class my_class
{
public:
my_class(void);
private:
void* my_thread_main(void*);
pthread_t my_thread_tid;
};
#endif // _TRIDA_H_
trida.cpp
#include "trida.h"
my_class::my_class (void)
{
cout << "Hello from my_class!";
pthread_create(&(this->my_thread_tid),
NULL,
&(this->my_thread_main),
NULL);
return;
}
my_class::~my_class (void)
{
/* pthread_join() */
return;
}
void * my_class::my_thread_main (void *) {
cout << "Hello from my_thread_main!";
return(0);
}
#include <iostream>
#include "trida.h"
using namespace std;
int main (int argc, char **argv)
{
my_class example;
cout << "Hello from main!\n";
return (0);
}
Pri prekladu dostanu toto:
g++ -c trida.cpp -o trida.o
trida.cpp: In constructor ‘my_class::my_class()’:
trida.cpp:9: error: ISO C++ forbids taking the address of a bound member function to form a pointer to member function. Say ‘&my_class::my_thread_main’
trida.cpp:10: error: cannot convert ‘void* (my_class::*)(void*)’ to ‘void* (*)(void*)’ for argument ‘3’ to ‘int pthread_create(pthread_t*, const pthread_attr_t*, void* (*)(void*), void*)’
trida.cpp: At global scope:
trida.cpp:15: error: definition of implicitly-declared ‘my_class::~my_class()’
make: *** [trida.o] Error 1
Dekuji vsem za pomoc! Tomas
V prvé řadě: IMHO není vůbec dobrý nápad dělat komunikaci přes port tak, že jedno vlákno posílá a druhé přijímá. Možná se mýlím, ale myslím, že to bude strašný bordel.
Metodu třídy my_main() máš deklarovanou jako metodu třídy my_class. Volání pthread_create() očekává ukazatel na funkci, ale ty se snažíš mu předat metodu třídy - to nemůžeš udělat, protože metoda třídy očekává navíc ukazatel na "this", který jí nemáš jak předat.
Fungovalo by to, kdyby byla metoda my_main() deklarována jako statická, a ukazatel na příslušný objekt my_class bys jí předával explicitně; potom můžeš tento ukazatel předat jako "uživatelská data" skrz volání pthread_create() a vymalováno.
Jo: zkus se inspirovat nějakou už hotovou C++ knihovnou.
Jako příklad se mrkni třeba na to, jak je udělaná třída QThread z Qt. Není to nijak těžké, jen je třeba udělat ten taneček okolo předávání pointeru na objekt.
No ale jak lze tedy efektivne resit pristup k portu? Kdyz select nelze pouzit protoze chci behem prijimani a odesilani delat neco jineho a ne cekat na data od portu.
Potrebuji totiz soubezne zpracovani dat na seriovem portu a provadeni jineho kodu.
Pokud by ale byla metoda staticka, tak to by znamenalo, ze by vsechny instance tridy meli tuto metodu spolecnou.
Ale ja bych chtel aby kazdy seriovy port mel sve dve vlakna.
Napis co vlastne potrebujes udelat (co ma ta aplikace delat kdyz se zrovna nepristupuje k seriaku), a myslim ze by bylo dobre zamyslet se nad tim jestli by to neslo resit jen s jednim vlaknem a neblokujicim ctenim, ve vetsine pripadu to jde a je to lepsi reseni nez s pomoci vlaken.
... btw, nechce ovládání krtka někdo naportovat do tuxánků nebo zatacky? Mohlo by pak u jednoho počítače hrát několik dalších hráčů -- používali by jeden mikrofon a tůůůů, hůůůů, tůůůůůůů, pííííísk.
Pripojuji se v tom smyslu, že dělat vlákna přes pthreads je v c++ zbytečná dřina. Osobně bych doporučil www.boost.org/doc/html/thread.html .
Pokud bude delat jen jeden programek v C++ tak je to overkill, pokud se tim bude dlouhodobe zabejvat, tak boost je jasna volba.
Přibere tím závislost navíc, ale co se týče čitelnosti kódu (a přenositelnosti, ale to je v tomto případě asi jedno), tak tím myslím získá.
#ifndef _TRIDA_H_
#define _TRIDA_H_
#include <iostream>
#include <pthread.h>
using namespace std;
class my_class
{
public:
my_class(void);
private:
static void* _entry(void*);
void* main();
pthread_t _id;
};
#endif // _TRIDA_H_
my_class::my_class (void)
{
cout << "Hello from my_class!";
pthread_create(&(this->_id), NULL, &_entry, NULL);
return;
}
my_class::~my_class (void)
{
/* pthread_join() */
return;
}
void* my_class::_entry (void* data)
{
my_class* thread = (my_class*)data;
return thread->main();
}
void *my_class::main()
{
cout << "Hello from my_thread_main!";
return(0);
}
Tiskni
Sdílej: