Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.
Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).
Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.
Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.
GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.
Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.
Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na
… více »Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.
Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.
Byl zveřejněn program konference Installfest 2026. Konference proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13. Vstup zdarma.
split_string, ktora berie parameter ret ako navratovu hodnotu. Potom naalokuje dvojrozmerne pole. A spravne.
int split_string (char **ret, char *str, unsigned char del)
{
ret = (char **) malloc (sizeof (char *) * (count + 1));
ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
}
Potom ju volam na tomto mieste:
char **row_parts = NULL;
unsigned int parts_count = split_string (row_parts, line, ';');
Tu to ale spadne.
printf ("%u %s\n", parts_count, row_parts[0]);
Preco je row_parts[0] nepovoleny pristup do pamati ak ret[0] v split_string je normalne dostupny?
Prikladam este vystup z debuggera:
Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_PROTECTION_FAILURE at address: 0x00000000
parse_row (line=0x400150 "chalupa") at proj4.c:169
169 printf ("%u %s\n", parts_count, row_parts[0]);
(gdb)
Vopred dakujem za kazdu radu.
Řešení dotazu:
split_string, proměnnou back_str atd.
Reason: KERN_PROTECTION_FAILURE at address: 0x00000000Přistupujete na adresu 0, čili derefernce NULL-pointeru. Skoro bych řekl, že tam ty hvězdičky v hlavičce funkce mají být 3 a parametr by se měl předávat jako
&row_parts), protože takhle to IMHO nezměníte. Čili bude stále NULL.
int split_string (char ***ret, char *str, unsigned char del)
{
...//tu sa s ret nepracuje
*ret = (char **) malloc (sizeof (char *) * (count + 1));
back_str = str;
for (i = 0; *back_str && i < strlen (str); i++)
{
printf ("%u: %ld", i, strlen (back_str));
*ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
Povodne som to aj mal s tymi 3 "hviezdickami", ale potom mam chybu vnutri tej split_string.
Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_PROTECTION_FAILURE at address: 0x00000c00
0x00002a25 in split_string (ret=0xbffff55c, str=0x400150 "chalupa", del=59 ';') at proj4.c:244
244 *ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
To sa mi ale velmi nezda, ten ret by uz mal byt na tom mieste alokovany ako ukazovatel na ukazovatele alebo sa mylim?
Este pre uplnost, tie ostatne premenne su nastavene spravne, takze by to miesto malo byt naalokovane dobre, sice neosetrujem tam zatial chyby mallocu, ale pamati mam zatial viac nez dost.
Dakujem za radu, nechcem byt nezdvorili, ale cely zdrojak sem dat nemozem.Taky nechci být nezdvořilý, ale tímhle si dost rapidně snížíte počet lidí, co budou ochotni odpovídat. O to ale nejde.
Povodne som to aj mal s tymi 3 "hviezdickami", ale potom mam chybu vnutri tej split_string.Střelím od boku, protože po půlnoci si s prioritou nejsem úplně jistý - je
*ret[i] správně uzávorkované - nemá to být (*ret)[i]?
Tiskni
Sdílej: