Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.
Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.
Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.
Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.
Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.
Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co
… více »Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).
Jeff Quast otestoval současné emulátory terminálu. Zaměřil se na podporu Unicode a výkon. Vítězným emulátorem terminálu je Ghostty.
Amazon bude poskytovat cloudové služby OpenAI. Cloudová divize Amazon Web Services (AWS) uzavřela s OpenAI víceletou smlouvu za 38 miliard USD (803,1 miliardy Kč), která poskytne majiteli chatovacího robota s umělou inteligencí (AI) ChatGPT přístup ke stovkám tisíc grafických procesů Nvidia. Ty bude moci využívat k trénování a provozování svých modelů AI. Firmy to oznámily v dnešní tiskové zprávě. Společnost OpenAI také nedávno
… více »Ř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: