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.
T-Mobile od 15. září zpřístupňuje RCS (Rich Communication Services) zprávy i pro iPhone.
Společnost ARM představila platformu Arm Lumex s Arm C1 CPU Cluster a Arm Mali G1-Ultra GPU pro vlajkové chytré telefony a počítače nové generace.
Unicode Consortium, nezisková organizace koordinující rozvoj standardu Unicode, oznámila vydání Unicode 17.0. Přidáno bylo 4 803 nových znaků. Celkově jich je 159 801. Přibylo 7 nových Emoji.
Apple představil (YouTube) telefony iPhone 17 Pro a iPhone 17 Pro Max, iPhone 17 a iPhone Air, sluchátka AirPods Pro 3 a hodinky Watch Series 11, Watch SE 3 a Watch Ultra 3.
Realtimová strategie Warzone 2100 (Wikipedie) byla vydána ve verzi 4.6.0. Podrobný přehled novinek, změn a oprav v ChangeLogu na GitHubu. Nejnovější verzi Warzone 2100 lze již instalovat také ze Snapcraftu a Flathubu.
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.
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: