Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.5 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.
Rodina jednodeskových počítačů Orange Pi se rozrostla (𝕏) o Orange Pi 6 Plus.
Na Humble Bundle běží akce Humble Tech Book Bundle: All Things Raspberry Pi by Raspberry Pi Press. Se slevou lze koupit elektronické knihy od nakladatelství Raspberry Pi Press a podpořit Raspberry Pi Press, Raspberry Pi Foundation North America nebo Humble.
Přidaný režim autonomního řízení vozidel Tesla Mad Max je dostupný pro vybrané zákazníky v programu EAP (Early Access Program). Nový režim je na silnici agresivnější, častěji mění pruhy a ne vždy dodržuje rychlostní limity. Agentura JPP spekuluje, že v Česku by se mohl nový režim namísto Mad Max jmenovat Mad Turek...
Byla vydána nová verze 9.18 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Nově také pro NanoPi R3S, R3S LTS, R76S a M5. Přehled novinek v poznámkách k vydání.
bat, tj. vylepšený cat se zvýrazňováním syntaxe a integrací s gitem, byl vydán ve verzi 0.26.0.
Byla vydána první verze 0.0.1 [Mastodon] multipatformního renderovacího jádra webového prohlížeče Servo (Wikipedie). Vývoj Serva započal v roce 2012 v Mozilla Corporation. V roce 2020 bylo Servo předáno nadaci Linux Foundation. Servo je napsané v programovacím jazyce Rust.
Cloudovou službu Amazon Web Services (AWS) americké firmy Amazon dnes postihl globální výpadek. Omezil dostupnost řady aplikací a webů, například populární platformu Snapchat nebo aplikaci s prvky umělé inteligence (AI) Perplexity. Podle webu Downdetector hlásily problémy také uživatelé obchodu Amazon, streamovací platformy PrimeVideo nebo platební služby PayPal.
GNU Octave lze nově používat ve webovém prohlížeči v JupyterLite s jádrem Xeus-Octave.
Od 3. do 16. listopadu proběhnou Dny AI 2025. V úterý 11. listopadu proběhne Open source AI day v Red Hatu v Brně.
char *pole_soubor[254];
...
...
pocet_radku++;
if (pocet_radku==254) {
if ((pole_soubor=realloc (pole_soubor, pocet_radku*2))==NULL) {
fprintf (stderr,"Chyba realokace!\n");
return 1;
}
pole_soubor[pocet_radku]=(char *) malloc (strlen (radek_zaloha)+1);
pole_soubor[pocet_radku]=radek_zaloha;
}
pole_soubor
jsou řádky, kam načítáš, a radek_zaloha
je jeden řetězec, ve kterém je uložen zrovna načtený řádek, tak musíš použít:
strcpy(pole_soubor[pocet_radku], radek_zaloha);
místo pole_soubor[pocet_radku]=radek_zaloha;
.
Realokace toho pole vypadá dobře.
man realloc
pocet_radku
, jestlize se dostane na 254 tak se ma pole realokovat na vyssi hodnotu.Alokace pro kazdy radek mam udelane a funkcni. Opravdu problem je v tom ze nejak nechapu vami uvedeny bod 2 a 3. To bude asik to proc se s tim nedokazu domluvit. Nyni jsem se dostal do nasledujici podminky if ((pole_soubor=realloc (pole_soubor, sizeof (char)*pocet_radku*2))==NULL)
a dostavam pri prekdladu nasledujici hlasku incompatible types in assignment
coz prelozeno znamena>>Nekompatybilni typ v priprazeni. To vsechno chapu ale jaky tam mam dat typ!? Jsem z toho magor jak to udelat.Prosim poradte nekdo nejak tak jako pro blbe(mne).
char **pole_radku;
/*definujeme pole polí znaků*/ char **pole_radku; /*alokujeme pole pro pocet_radku řádků*/ pole_radku = (char **) malloc (sizeof(char *) * pocet_radku);
pole_radku
je potom možné použít jako parametr funkce realloc
, kdežto staticky definované pole char *pole_radku[254]
realokovat nejde.
bod 3: velikost je v bajtech, ale každý řádek je ukazatel na pole znaků, tzn. má velikost 4B. Tím pádem bys svým reallocem velikost změnil na pocet_radku/4
řádků. Správné volání je tedy:
pole_radku = (char **) realloc (pole_radku, sizeof(char*) * pocet_radku *2);
(doufám, že tam nemám chybu #include <stdio.h> #include <sys/mman.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <malloc.h> int getNthLine(int n, int *lines, int termcount, char *file_ptr, int filesize, char **line_ptr, int *linelen){ int begin, end; if (n == 0){ begin = 0; } else{ begin = lines[n - 1] + 1; } if (n == termcount){ end = filesize; } else{ end = lines[n]; } *line_ptr = file_ptr + begin; *linelen = end - begin; return 0; } int main(int argc, char **argv){ char *filename = argv[1]; /*UGLY*/ char *file_ptr = NULL; int *lines = NULL; char *line_ptr = NULL; int fdstdout, linelen, filesize, fd, i, termcount = 0, allocated = 0; struct stat filestat; int alloc_ahead = getpagesize(); /* allocated memory will always be multiple of page size*/ fd = open(filename, O_RDONLY); fstat(fd, &filestat); filesize = filestat.st_size; printf("size is %d bytes\n", filesize); file_ptr = mmap(0, filesize, PROT_READ, MAP_PRIVATE, fd, 0); if (!file_ptr){ printf("mmap failed\n"); return -1; } close(fd); for (i=0; i<filesize; i++){ if ('\n' == file_ptr[i]){ if (termcount >= allocated){ allocated = termcount + alloc_ahead; lines = (int *)realloc(lines, allocated*sizeof(lines)); printf("(re)allocated memory for %d items\n", allocated); } lines[termcount] = i; termcount++; } } fdstdout = fileno(stdout); for(i=0; i<=termcount; i++){ getNthLine(i, lines, termcount, file_ptr, filesize, &line_ptr, &linelen); printf("%3d.line(%3d bytes): ", i + 1, linelen); fwrite(line_ptr, linelen, 1, stdout); fwrite("\n", 1, 1, stdout); } munmap(file_ptr, filestat.st_size); return 0; }
Tiskni
Sdílej: