PSF (Python Software Foundation) po mnoha měsících práce získala grant ve výši 1,5 milionu dolarů od americké vládní NSF (National Science Foundation) v rámci programu "Bezpečnost, ochrana a soukromí open source ekosystémů" na zvýšení bezpečnosti Pythonu a PyPI. PSF ale nesouhlasí s předloženou podmínkou grantu, že během trvání finanční podpory nebude žádným způsobem podporovat diverzitu, rovnost a inkluzi (DEI). PSF má diverzitu přímo ve svém poslání (Mission) a proto grant odmítla.
Balík nástrojů Rust Coreutils / uutils coreutils, tj. nástrojů z GNU Coreutils napsaných v programovacím jazyce Rust, byl vydán ve verzi 0.3.0. Z 634 testů kompatibility Rust Coreutils s GNU Coreutils bylo úspěšných 532, tj. 83,91 %. V Ubuntu 25.10 se již používá Rust Coreutils místo GNU Coreutils, což může přinášet problémy, viz například nefunkční automatická aktualizace.
Od 3. listopadu 2025 budou muset nová rozšíření Firefoxu specifikovat, zda shromažďují nebo sdílejí osobní údaje. Po všech rozšířeních to bude vyžadováno někdy v první polovině roku 2026. Tyto informace se zobrazí uživateli, když začne instalovat rozšíření, spolu s veškerými oprávněními, která rozšíření požaduje.
Jste nuceni pracovat s Linuxem? Chybí vám pohodlí, které vám poskytoval Microsoft, když vás špehoval a sledoval všechno, co děláte? Nebojte se. Recall for Linux vám vrátí všechny skvělé funkce Windows Recall, které vám chyběly.
Společnost Fre(i)e Software oznámila, že má budget na práci na Debianu pro tablety s cílem jeho vyžívání pro vzdělávací účely. Jako uživatelské prostředí bude použito Lomiri.
Proběhla hackerská soutěž Pwn2Own Ireland 2025. Celkově bylo vyplaceno 1 024 750 dolarů za 73 unikátních zranitelností nultého dne (0-day). Vítězný Summoning Team si odnesl 187 500 dolarů. Shrnutí po jednotlivých dnech na blogu Zero Day Initiative (1. den, 2. den a 3. den) a na YouTube.
Byl publikován říjnový přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Pracuje se na podpoře M3. Zanedlouho vyjde Fedora Asahi Remix 43. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.
Iniciativa Open Device Partnership (ODP) nedávno představila projekt Patina. Jedná se o implementaci UEFI firmwaru v Rustu. Vývoj probíhá na GitHubu. Zdrojové kódy jsou k dispozici pod licencí Apache 2.0. Nejnovější verze Patiny je 13.0.0.
Obrovská poptávka po plynových turbínách zapříčinila, že datová centra začala používat v generátorech dodávajících energii pro provoz AI staré dobré proudové letecké motory, konvertované na plyn. Jejich výhodou je, že jsou menší, lehčí a lépe udržovatelné než jejich průmyslové protějšky. Proto jsou ideální pro dočasné nebo mobilní použití.
Typst byl vydán ve verzi 0.14. Jedná se o rozšiřitelný značkovací jazyk a překladač pro vytváření dokumentů včetně odborných textů s matematickými vzorci, diagramy či bibliografií.
FILE *p_f=fopen("soubor.txt","r+");, soubor přitom soubor existuje. Dále mám if(p_f==NULL){
printf("Chyba pri otevirani souboru\n");
fclose(p_f);
}. Všechny potřebné knihovny jsou inkluovány, tak nevím kde je chyba. Googlem brázdím něco přes hodinu a půl a na nic jsem nepřišel. Jen jsem zjistil, že je tam potřeba použít fce malloc, bohužel jsem začátečník, tak nevím jak dál. Používám pro studium knihu od K&R. Díky všem za nápady.
Řešení dotazu:
if ((vstup=fopen("soubor.txt","r")))
{
/* zpracování ... */
fclose(vstup);
}
else
printf("Nelze otevřít soubor pro čtení!\n\a");
if ((vstup=fopen("soubor.txt","r"))) {
if((fgets(pointer,10000000,vstup))==NULL) {
printf("Chyba 1 \n");
}
pointer=druhe_pole;
if((fgets(pointer,10000000,vstup))==NULL) {
printf("Chyba 2 \n");
}
fclose(vstup);
}
else {
printf("Chyba pri otevirani souboru\n\a");
} Váš kód mi fungoval bezproblému, děkuji za něj, bohužel, i když jsem to spravil, nepomohlo to.
pointer, máte tam rezervováno místo pro 10 000 000 bytů (charů) na to dám krk 
#include <stdio.h>
#include <stdlib.h>
#define MY_SIZE (100000)
//main.cpp
int main(int argc, char **argv)
{
char *pointer = NULL;
char *prvni_pole = NULL;
char *druhe_pole = NULL;
if((prvni_pole = (char*) malloc(sizeof(char) * MY_SIZE)) == NULL)
{
printf("Chyba 0-1, nedostatek paměti\n");
exit(3);
}
if((druhe_pole = (char*) malloc(sizeof(char) * MY_SIZE)) == NULL)
{
printf("Chyba 0-2, nedostatek paměti\n");
free(prvni_pole);
exit(3);
}
//aspon
prvni_pole[0] = druhe_pole[0] = 0x0;
//nebo cela alokovana pamet:
//memset(prvni_pole,0x0,MY_SIZE);
//memset(druhe_pole,0x0,MY_SIZE);
FILE *vstup;
if ((vstup=fopen("soubor.txt","r")) == NULL) {
printf("Chyba pri otevirani souboru\n");
exit(3);
}
//ukazatel na první pole i když se m;že použít přímo prvni_pole
pointer = prvni_pole;
if((fgets(pointer,MY_SIZE,vstup))==NULL) {
printf("Chyba 1 \n");
}
if(feof(vstup)){
printf("Chyba uz tam teho vice není\n");
}
else
{
//ukazatel na druhe pole i když se může použít přímo druhe_pole
pointer=druhe_pole;
if((fgets(pointer,MY_SIZE,vstup))==NULL) {
printf("Chyba 2 \n");
}
}
//obvykle netestuje návratovou hodnotu
fclose(vstup);
printf("prvni_pole: %s\n",prvni_pole);
printf("druhe_pole: %s\n",druhe_pole);
//neuskodi
pointer=NULL;
if(prvni_pole != NULL)//fcil zbytecne
free(prvni_pole);
//mozna dobry navyk
prvni_pole=NULL;
if(druhe_pole != NULL)//fcil zbytecne
free(druhe_pole);
//mozna dobry navyk
druhe_pole=NULL;
return 0;
}
char prvni_pole[MY_SIZE];? Dynamicke alokaci se snazi clovek co nejvice vyhnout...
Proc proboha alokujes pole dynamicky?Protože 20MB (dle původního dotazu) nechci jinak.
Dynamicka alokace je mnohem pomalejsi, nez staticka.Rozdíl rychlosti alokace bude neměřitelný a výsledek možná opačný pokud proměnné budou mimo fci main.
Co ti brani v tom, pouzit…Brání mi rozum a ohled na ostatní.
Dynamicke alokaci se snazi clovek co nejvice vyhnout...Dle této definice nejsem člověk
(nebudu se ji vyhýbat za každou cenu), ale vidím to spíše tak, že rozumný programátor použijte to, co je v daném případě lepší a ví kde a jak se, která „rezervace paměti“ provádí…
FILE *fp;
if ((fp = fopen("myfile", "r")) == NULL ) {
perror("unable to open file");
return -1;
}
/* praca so suborom a nasledne close */
fclose(fp);
return 0;
pri uceni je vhodne pouzit aj debugger, napriklad gdb. google ti da vela quick howto ako co .. v tvojom pripadne napriklad:
$ gcc -g -o atest test.c
$ ./atest
attempt to close empty null handle
Segmentation fault: 11 (core dumped)
$
$ gdb ./atest atest.core
GNU gdb 6.1.1 [FreeBSD]
--[snip]--
(gdb) where
#0 0x0000000800719e37 in fclose () from /lib/libc.so.7
#1 0x0000000000400686 in main () at test.c:8
(gdb) list 8
3 int main() {
4 FILE *p_f = fopen("soubor.txt","r+");
5
6 if(p_f == NULL ) {
7 fprintf(stderr, "attempt to close empty null handle\n");
--- vystup z where -> 8 fclose(p_f);
9 }
10
11 return 0;
12 }
kde atest je tvoj spustitelny program, core file sa vygeneroval po segfaulte.
Tiskni
Sdílej: