Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.
Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.
Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Americká technologická společnost Apple uskuteční v USA další investice ve výši sta miliard dolarů (2,1 bilionu korun). Oznámil to ve středu šéf firmy Tim Cook při setkání v Bílém domě s americkým prezidentem Donaldem Trumpem. Trump zároveň oznámil záměr zavést stoprocentní clo na polovodiče z dovozu.
Zálohovací server Proxmox Backup Server byl vydán v nové stabilní verzi 4.0. Založen je na Debianu 13 Trixie.
Byla vydána nová verze 1.54.0 sady nástrojů pro správu síťových připojení NetworkManager. Novinkám se v příspěvku na blogu NetworkManageru věnuje Jan Václav.
Knižní edice správce české národní domény přináší novou knihu zkušeného programátora Pavla Tišnovského s názvem Programovací jazyk Go. Publikace nabízí srozumitelný a prakticky zaměřený pohled na programování v tomto moderním jazyce. Nejedná se však o klasickou učebnici, ale spíše o průvodce pro vývojáře, kteří s Go začínají, nebo pro ty, kdo hledají odpovědi na konkrétní otázky či inspiraci k dalšímu objevování. Tištěná i digitální verze knihy je již nyní k dispozici u většiny knihkupců.
OpenAI zpřístupnila (en) nové nenáročné otevřené jazykové modely gpt-oss (gpt-oss-120b a gpt-oss-20b). Přístupné jsou pod licencí Apache 2.0.
Byla vydána RC verze openSUSE Leap 16. S novým instalátorem Agama, Xfce nad Waylandem a SELinuxem.
Google Chrome 139 byl prohlášen za stabilní. Nejnovější stabilní verze 139.0.7258.66 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 12 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře. S verzí 139 přestal být podporován Android 8.0 (Oreo) a Android 9.0 (Pie).
Dobry den, trochu si hraji se socketama v linuxu, takovy maly chat jen mezi dvema pocitaci, jednoduse se pripojim k druhemu stroji, ten muze poslat data nebo naopak je mohu poslat ja.
Mam trochu problem jak do jednoho programu vmesnat i to odesilani, umim prijimat data, cekam v nekonecne smycce a ctu data ze socketu, pokud se nejaka objevi tak je jen zobrazim.
Lze nejak zaridit neblokujici volani read? Abych mohl dovolit uzivateli v tu chvili i zadavat data, ukoncit enterem a odeslat?
Nebo lze nejak zaridit, aby se po prichodu dat vyvolava nejaka mnou definovana fce? Nebo treba signal.
Nebo tuto ulohu musim rozdeli do vlakna ve kterem budu jen cist data ze site a v hlavnim main programu budu cekat na uzivatelsky vstup a ten odesilat do site?
Jo abych nezapomel, pisu to v jazyce C.
Dekuji za info jak toto vyresit.
O_NONBLOCK
rovnou při volání open()
nebo ho následně nastavit pomocí fcntl()
. U socketu to asi jde jen tím druhým způsobem. Obvykle dávám přednost čtení v samostatném threadu nebo procesu, ale ve vašem případě bude možná neblokující čtení v kombinaci s poll()
(nebo select()
) jednodušší.
time
(nebo daytime
, nikdy si nepamatuji, která je která), mp-poll
funguje pomocí poll()
, mp-fork
používá samostatné procesy a mp-thread
samostatná vlákna. Není to sice zrovna to, co byste potřeboval (tahle služba od klienta nic nečte), ale třeba vám to k něčemu bude.
int sock; ... struct timeval timeout; timeout.tv_usec = 0; char buffer[BUFFER_SIZE]; ssize_t ret; fd_set sock_set; FD_ZERO(&sock_set); while(1) { timeout.tv_sec = TIMEOUT; /* nastaveni deskriptoru ktere budem sledovat */ FD_SET(sock, &sock_set); FD_SET(STDIN_FILENO, &sock_set); /* sledovani deskriptoru */ if((ret = select(MAX(sock, STDIN_FILENO)+1, &sock_set, 0, 0, &timeout)) == -1) /* osetreni chyby */ /* pokud lze cist ze socketu */ if(FD_ISSET(sock, &sock_set)) { if((ret = recv(sock, buffer, BUFFER_SIZE, O_NONBLOCK) == -1) /* osetreni chyby */ if(ret == 0) break; if((ret = write(STDOUT_FILENO, buffer, ret)) == -1) /* osetreni chyby */ } /* pokud lze cist ze std. vstupu */ if(FD_ISSET(STDIN_FILENO, &sock_set)) { if((ret = read(STDIN_FILENO, buffer, BUFFER_SIZE)) == -1) /* osetreni chyby */ */ if(ret == 0) break; if((ret = send(sock, buffer, ret, O_NONBLOCK) == -1) /* osetreni chyby */ } ... }
int oldFlag = fcntl( sock_id, F_GETFL, 0 ); fcntl( sock_id, F_SETFL, oldFlag | O_NONBLOCK );
Tiskni
Sdílej: