Byli vyhlášeni vítězové ocenění Steam Awards 2025. Hrou roku a současně nejlepší hrou, která vám nejde, je Hollow Knight: Silksong.
Byla vydána nová verze 26.0 linuxové distribuce Manjaro (Wikipedie). Její kódové jméno je Anh-Linh. Ke stažení je v edicích GNOME, KDE PLASMA a XFCE.
Jednotný seznam blokovaných internetových stránek vedený Českým telekomunikační úřadem obsahoval také Český telekomunikační úřad.
Byl představen webový prohlížeč Brow6el, běžící v terminálu. Pro prohlížení webu je využit Chromium Embedded Framework, vyrendrovaná webová stránka je následně zobrazena v terminálu převodem na sixely pomocí knihovny libsixel. Brow6el se ovládá modálním klávesnicovým rozhraním, inspirovaném populárním textovým editorem Vim. Demonstrační video s ukázkou používání.
Společnost Pebble představila (YouTube) chytré hodinky Pebble Round 2. S kulatým e-paper displejem, s open source PebbleOS a vydrží baterie přibližně dva týdny. Předobjednat je lze za 199 dolarů s plánovaným dodáním v květnu.
Na novoroční inauguraci starosty New Yorku Zohrana Mamdaniho bylo zakázáno si s sebou přinést Raspberry Pi anebo Flipper Zero. Raspberry Pi i Flipper Zero jsou explicitně uvedeny v seznamu zakázaných věcí jak na na veřejné pozvánce, tak i na oficiálních stránkách města.
OpenTTD (Wikipedie), tj. open source klon počítačové hry Transport Tycoon Deluxe, byl vydán v nové stabilní verzi 15.0. Přehled novinek v seznamu změn a také na YouTube. OpenTTD lze instalovat také ze Steamu.
Správce oken IceWM byl vydán ve verzi 4.0.0, která např. vylepšuje navigaci v přepínání velkého množství otevřených oken.
Od 1. ledna 2026 jsou všechny publikace ACM (Association for Computing Machinery) a související materiály přístupné v její digitální knihovně. V rámci této změny je nyní digitální knihovna ACM nabízena ve dvou verzích: v základní verzi zdarma, která poskytuje otevřený přístup ke všem publikovaným výzkumům ACM, a v prémiové zpoplatněné verzi, která nabízí další služby a nástroje 'určené pro hlubší analýzu, objevování a organizační využití'.
Řešení dotazu:
Ale když je hvězdička za typem char, co to znamená?C ignoruje mezery, tudíž následující 3 řádky jsou ekvivalentní:
char *a char* a char * aZ hlediska chování je IMHO nejlogičtější
char *a (kvůli problémům typu int *a, b), ale ve zdrojácích najdete všechny 3 způsoby.
Jinak, co znamená int set(char* in, char** out) záleží na kontextu, protože buď může být vstupem řetězec znaků nebo odkaz na jediný znak (což je sice z pohledu C totéž, ale logicky je to něco jiného).
int getstringcopy(char *src, char **dst)
{
*dst=malloc(1+strlen(src));
if (*dst)
{
strcpy(*dst,src);
return 1;
}
else
return 0;
}
char *src="foo";
char *out=NULL;
if (getstringcopy(src,&out))
{
printf("podarilo sa");
....
free(out);
}
Skratka v tom výstupnom parametri nie je jednoduchý typ, ale pointer.
char * vstup = "abcde";
char * vystup;
int odp;
...
odp = set(vstup, &vystup);
printf("%s -> %s\n", vstup, vystup);
// pokud by byl pouze set(char *, char *), tak
// by to typicky vypadalo nějak takhle
char vystup[50]; // resp. vhodná konstanta pro max. velikost
odp = set(vstup, vystup);
printf("%s -> %s\n", vstup, vystup);
A rozhodně doporučuji si přečíst v nějaké učebnici, jak ty ukazatele doopravdy fungují, protože příklady mohou být dost zavádějící.
i++ + j
a
i + ++j
znamená něco dost jiného a rozdíl působí právě ty mezery.
Parsování C lze popsat tak, že se prostě berou znaky, dokud z nich lze vytvořit platný token jazyka (identifkátor, operátor, číslo, etc.). Až to přestane jít, ať už proto, že se narazí na mezeru nebo na něco jiného, co se nehodí, tak se ten token ukončí a začnou se zase znovu brát znaky, dokud něco dávají. Tudíž
i+++j
je ekvivalentní s první ukázkou, nikoli s druhou.
Dvě hvězdičky znamenají prostě pointer na pointer. Tři pointer na pointer na pointer, etc.
Je-li výstupem prostě řetězec, tak to ta funkce třeba alokuje. Tudíž má ,výstupní` parametr typu char*, ale jelikož ho modifikuje, předává se pointer na tohle, což je char**.
int set(char* in, char** out) novy string vo svojom tele, ktory potom ziskas cez out ? nieco ako:
char* msg = "hello, world";
char* out;
..
set (msg, &out);
..
kde set vola niekde v tele
int set(char* in, char** out)
{
..
char* buf= malloc( ..
..
*out = buf;
..
}
pisem z hlavy, chyby tam byt mozu .. ale principialne si take cosi nerobi
Tiskni
Sdílej: