Byla vydána nová verze 9.7 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání.
Vývojáři webového prohlížeče Ladybird dnes oznámili, že mění způsob vývoje. S blížícím se vydáním alfa verze přestávají přijímat veřejné pull requesty. Všechny otevřené veřejné pull requesty budou uzavřeny. Tým nedokáže garantovat bezpečnost AI generovaných pull requestů.
OpenLogi (GitHub) je open source náhrada aplikace Logi Options+ pro přizpůsobení myší od společnosti Logitech. Zatím běží pouze na macOS.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za květen (YouTube).
Úřad pro ochranu osobních údajů řeší desítky stížností na jednotné měsíční hlášení zaměstnavatele, které stát spustil počátkem dubna. Systém, jenž má firmám odlehčit od desítek formulářů, nejenže výrazně zatížil jejich účetní oddělení, ale docházelo v něm i k únikům osobních dat zaměstnanců k firmám, kde nepracovali. Podle ministerstva práce a sociálních věcí stála za problémem technická chyba. „Incident se týkal několika stovek
… více »Byla vydána (𝕏, Bluesky) nová verze 22.0.0 open source webového aplikačního frameworku Angular (Wikipedie). Přehled novinek v příspěvku na blogu.
Vim Classic byl vydán ve verzi 8.3. Drew DeVault oznámil tento fork editoru Vim (verze 8.2.0148, tj. těsně před zavedením Vim9 skriptování) v březnu letošního roku. Důvodem forku bylo, že vývojáři editorů Vim a Neovim začali při vývoji využívat LLM.
Open source konference DevConf.CZ 2026 proběhne 18. a 19. června v Brně na FIT VUT. Publikován byl program a spuštěna byla registrace.
Společnost JetBrains uvolnila verzi 2 svého open-source velkého jazykového modelu (LLM) pro vývojáře Mellum.
Probíhá konference Microsoft Build 2026. Microsoft představuje své novinky: kvantový čip Majorana 2, Surface Laptop Ultra a Surface RTX Spark Dev Box s NVIDIA RTX Spark, Intelligent Terminal, Coreutils for Windows (fork Rust Coreutils), AI modely MAI, AI agenta Scout, platformu pro agent-first zařízení Project Solara, …
Ř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: