Bylo vydáno openSUSE Leap 16 (cs). Ve výchozím nastavení přichází s vypnutou 32bitovou (ia32) podporou. Uživatelům však poskytuje možnost ji ručně povolit a užívat si tak hraní her ve Steamu, který stále závisí na 32bitových knihovnách. Změnily se požadavky na hardware. Leap 16 nyní vyžaduje jako minimální úroveň architektury procesoru x86-64-v2, což obecně znamená procesory zakoupené v roce 2008 nebo později. Uživatelé se starším hardwarem mohou migrovat na Slowroll nebo Tumbleweed.
Ministerstvo průmyslu a obchodu (MPO) ve spolupráci s Národní rozvojovou investiční (NRI) připravuje nový investiční nástroj zaměřený na podporu špičkových technologií – DeepTech fond. Jeho cílem je posílit inovační ekosystém české ekonomiky, rozvíjet projekty s vysokou přidanou hodnotou, podpořit vznik nových technologických lídrů a postupně zařadit Českou republiku mezi země s nejvyspělejší technologickou základnou.
… více »Radicle byl vydán ve verzi 1.5.0 s kódovým jménem Hibiscus. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.
Společnost OpenAI představila text-to-video AI model Sora 2 pro generování realistických videí z textového popisu. Přesnější, realističtější a lépe ovladatelný než předchozí modely. Nabízí také synchronizované dialogy a zvukové efekty.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.0, tj. první stabilní vydání založené na Ubuntu 24.04 LTS.
Rakouská armáda přechází na LibreOffice. Ne kvůli licencím (16 000 počítačů). Hlavním důvodem je digitální suverenita. Prezentace v pdf z LibreOffice Conference 2025.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) upozorňuje na sérii kritických zranitelností v Cisco Adaptive Security Appliance (ASA) a Firepower Threat Defense (FTD) a Cisco IOS, CVE-2025-20333, CVE-2025-20363 a CVE-2025-20362. Zneužití těchto zranitelností může umožnit vzdálenému neautentizovanému útočníkovi spustit libovolný kód (RCE). Společnost Cisco uvedla, že si je vědoma aktivního zneužívání těchto zranitelností.
Ochrana uživatelů a zároveň příznivé podmínky pro rozvoj umělé inteligence (AI). Ministerstvo průmyslu a obchodu (MPO) připravilo minimalistický návrh implementace evropského nařízení o umělé inteligenci, tzv. AI aktu. Český zákon zajišťuje ochranu občanům a bezpečné používání AI, ale zároveň vytváří pro-inovační prostředí, ve kterém se může AI naplno rozvíjet, firmy mohou využít jeho potenciál a nebudou zatíženy zbytečnou administrativou. Návrh je nyní v meziresortním připomínkovém řízení.
Dle plánu Linus Torvalds odstranil souborový systém bcachefs z mainline Linuxu. Tvůrce bcachefs Kent Overstreet na Patreonu informuje, že bcachefs je nově distribuován jako DKMS modul.
PIF, Silver Lake a Affinity Partners kupují videoherní společnost Electronic Arts (EA) za 55 miliard dolarů (1,14 bilionu korun).
Access not within mapped region at address 0x0 ==26680== at 0x3BD606CD90: fwrite (in /usr/lib64/libc-2.17.so)Je mozne, ze se nekdy nejak nekorektne otevre soubor pro psani? Premyslim, v cem to muze byt. Lze kod nejak osetrit tak, aby to bylo vzdy korektni?
void send_file(char *source, char *destination) { FILE * filer, * filew; int numr, numw; char buffer[1024]; if ((filer = fopen(source, "rb")) == NULL) { perror("open read file error.\n"); //exit(1); } if ((filew = fopen(destination, "wb")) == NULL) { perror("open write file error.\n"); //exit(1); } while (feof(filer) == 0) { if ((numr = fread(buffer, 1, 100, filer)) != 100) { if (ferror(filer) != 0) { perror("read file error.\n"); //exit(1); } else if (feof(filer) != 0); } if ((numw = fwrite(buffer, 1, numr, filew)) != numr) { perror("write file error.\n"); //exit(1); } } fclose(filer); fclose(filew); }
Řešení dotazu:
A nejsou právě problémem ty zakomentované exit-y?, tedy dle hlášky zrovna ten ve fopen pro filew.
U zapisovaného souboru je dobré kontroloval návratový kód fclose, moc se to sice nedělá, ale…
#include <stdlib.h> #include <unistd.h> #include <stdio.h> void send_file(const char *source, const char *destination) { FILE * filer, * filew; int numr; const int SIZE_OF_BUFFER=1024; char buffer[SIZE_OF_BUFFER]; if ((filer = fopen(source, "rb")) == NULL) { perror("open read file error.\n"); exit(1); } if ((filew = fopen(destination, "wb")) == NULL) { perror("open write file error.\n"); fclose(filer); exit(1); } while (feof(filer) == 0) { if ((numr = fread(buffer, 1, SIZE_OF_BUFFER, filer)) != SIZE_OF_BUFFER) { if (ferror(filer) != 0) { perror("read file error.\n"); fclose(filer); fclose(filew); exit(1); } } if (fwrite(buffer, 1, numr, filew) != numr) { perror("write file error.\n"); fclose(filer); fclose(filew); exit(1); } } if(fclose(filer) != 0) printf("read file - close error.\n");//has read-file been deleted ... ??? if(fclose(filew) != 0) printf("write file - close error.\n");//flush C buffer fails //fsync ???? } int main( int argc, const char* argv[] ){ if (argc == 3 ) { send_file(argv[1], argv[2]); } else { printf("Main error, two params needed (from, to).\n"); return 1; } return 0; }
Tiskni
Sdílej: